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内 容 简 介 


本 书 从 初学 者 角度 出 发 ， 以 基础 知识 为 “基石 ”， 以 核心 技术 和 高 级 应 用 为 “ 梁 柱 ”， 最 终 通过 实战 项 目 来 检验 成 
果 ， 这 就 是 本 书 的 编写 思路 。 本 书 突出 “基础 ”、“ 全 面 ”、“ 深 入 ”， 强 调 “ 实 战 ”效果 。 在 介绍 技术 的 同时 ， 各 章 
都 提供 有 示例 或 稍 大 一 些 的 实例 ,同时 在 各 章 的 结尾 通过 几 个 小 型 项 目 来 综合 应 用 本 章 所 讲解 的 知识 , 做 到 理论 与 实践 
相 结 合 。 最 后 提供 5 个 完整 的 项 目 实例 ， 详 细 讲 述 从 前 期 规划 、 系 统 设计 ， 到 项 目 开 发 的 全 部 实现 过 程 。 

全 书 共 分 29 章 , 包括 初 识 PHP，PHP 环境 搭建 ，PHP 语言 基础 ， 流 程控 制 语句 ， 函 数 ， 字 符 串 ， 正 则 表达 式 , PHP 
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例 进行 介绍 ， 对 涉及 的 程序 代码 给 出 了 详细 的 注释 ， 可 以 使 读者 轻松 领会 PHP 程序 开发 的 精髓 ， 快 速 提高 开发 技能 。 
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的 答案 。 
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PHP 是 全 球 最 普及 、 应 用 最 广泛 的 互联 网 开发 语言 之 一 。PHP 语言 具有 简单 、 易 学 、 源 码 开放 ， 
可 操纵 多 种 主流 与 非 主 流 的 数据 库 ， 支 持 面向 对 象 的 编程 ， 支 持 多 种 开源 框架 〈 如 Zend Framework) ， 
支持 跨 平 台 的 操作 ， 而 且 完 全 免费 等 特点 ， 越 来 越 受 到 广大 程序 员 的 青睐 和 认同 。PHP 目前 拥有 几 百 
万 个 用 户 , 其 发 展 速度 要 快 于 在 它 之 前 的 任何 一 种 计算 机 语言 。 相信 PHP 一 定 能 够 经 得 起 实践 的 检验 ， 
发 展 成 为 互联 网 开发 语言 中 “主流 的 主流 ”。 


本 书 内 容 


从 初学 程序 开发 的 人 员 步 入 到 编程 高 手 行列 通常 需要 经 历 3 个 阶段 ， 如 下 图 所 示 。 
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技术 应 用 实战 


本 书 中 的 内 容 也 是 按照 这 一 规律 精心 组 织 的 ， 将 从 初学 者 入 门 到 成 为 编程 高 手 所 必 备 的 各 类 知识 
分 成 4 个 部 分 ， 大 体 结构 如 下 图 所 示 。 
第 1 部 分 ， 基础 知识 
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编程 高 手 


站 郑 泪 贡 珊 上 内 


第 3 部 分 ， 高 级 应 用 


从 项 目 规划 、 系 统 分 析 、 系 统 设计 ， 
第 4 部 分 : 项 目 实战 到 项 目 实施 ， 全 程 进行 讲解 ， 附 有 图 
解 和 视频 录像 
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第 1 部 分 : 基础 知识 。 通 过 初 识 PHP、PHP 环境 搭建 、PHP 语言 基础 、 流 程控 制 语句 、 函 数 、 字 
符 串 、 正 则 表达 式 、PHP 数组 、PHP 与 Web 页 面 交 互 、PHP 与 JavaScript 交互 、 日 期 和 时 间 等 章节 
并 结合 大 量 的 图 示 、 示 例 、 综 合 实例 以 及 录像 等 ， 帮 助 读者 快速 掌握 PHP 语言 ， 并 为 以 后 编程 黄 定 坚 
实 的 基础 。 

第 2 部 分 : 核心 技术 。 介 绍 了 Cookie 与 Session、 图 形 图 像 、 文 件 系 统 、 面 向 对 象 、PHP 加 密 技 
术 、MySQL 数据 库 基本 基础 、 phpMyAdmin 图 形 化 管理 工具 、 使 用 MySQL 函数 操作 数据 库 、 ADODB 
类 库 、PHP 程序 调试 与 异常 处 理 等 。 学 习 完 这 一 部 分 ， 能 够 开发 数据 库 应 用 程序 和 一 些 中 小 型 的 热点 
模块 。 

第 3 部 分 : 高 级 应 用 。 介 绍 了 XML 技术 、Ajax 技术 和 Smarty 模板 技术 。 学 习 完 这 一 部 分 ， 能 够 

开发 一 些 实用 的 网 络 程序 等 。 
第 4 部 分 : 项 目 实战 。 作 者 精心 挑选 并 开发 了 5 个 大 型 完整 的 项 目 。 这 5 个 项 目 涵盖 了 MySQL 
数据 库 、Smarty 模板 技术 、ADODB 类 库 、Ajax 等 主流 技术 。 运 用 软件 工程 的 设计 思想 ， 让 读者 学 习 
如 何 进行 网 站 项 目的 实践 开发 。 书 中 按照 编写 项 目 计 划 书 一 系统 设计 一 数据 库 设计 一 创建 项 目 一 实现 
项 目 一 运行 项 目 一 解决 开发 常见 问题 一 发 布 网 站 的 过 程 进行 介绍 ， 引 领 读 者 一 步 一 步 亲身 体验 开发 项 
目的 全 过 程 ， 使 读者 可 以 巩固 前 面 所 学 的 知识 和 技术 ， 积 累 项 目 开 发 经 验 。 


本 书 特点 


口 ” 配 备 全 程 同步 语音 视频 讲解 。 
本 书 DVD 光盘 提供 了 覆盖 全 书 的 语音 视频 讲解 , 读者 可 以 通过 视频 快速 、 直 观 、 轻 松 地 学 习 。 
口 ”提供 大 量 的 实战 模块 、 实 战 案 例 、 实 战 练习 。 
为 了 增强 读者 动手 能 力 ， 激 发 学 习 兴 趣 ， 本 书 提供 了 大 量 实战 模块 、 实 战 案例 ， 读 者 一 定 要 
仔细 研读 这 些 模块 ， 并 亲自 动手 调试 。 
口 ”提供 本 书 所 有 实例 的 源 程序 。 
本 书 光盘 提供 了 所 有 实例 的 源 程序 ， 读 者 不 必 逐 字 逐 句 录入 ， 可 直接 复制 ， 先 比 猫 画 虎 试 着 
做 一 遍 ， 可 以 提高 学 习 效率 ， 模 仿 是 最 快 的 学 习 方式 。 
口 ” 本 书 所 有 习题 和 实战 都 给 出 了 答案 ， 读 者 可 以 对 照 查阅 。 


读者 对 象 
回 有 志 于 软件 开发 的 初学 者 高 等 院 校 计算 机 相关 专业 的 老师 和 学 生 
回 准备 从 事 软件 开发 的 求职 者 参与 毕业 设计 的 学 生 
回 初中 级 程序 开发 人 员 程序 测试 及 维护 人 员 

技术 支持 与 服务 


有 关于 本 书 的 问题 ， 读 者 可 以 通过 如 下 方式 与 我 们 沟通 : 


六 


of 


1. 登录 本 技术 网 站 : www.mingribook.com， 查 阅 相 关 问 题 或 者 留言 。 
2. 通过 邮箱 : tmoonbook@sina.com 或 也 press@263.net。 

3. 加 入 QQ: 100310063 。 

最 后 ， 感 谢 您 选择 本 书 ， 希 望 本 书 能 成 为 您 编程 路 上 的 领航 者 。 

祝 读书 快乐 ! 
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初 识 PHP 


PHP 是 一 种 服务 器 端的 谈 入 式 和 脚本 语言 ， 是 一 种 路 平 台 、 面 向 对 象 、HTML 
嵌入 式 的 脚本 语言 。 本 章 将 向 读者 简单 介绍 PHP 语言 和 PHP 5 的 新 特性 、PHP 的 
语言 优势 、 常 用 代码 编辑 工具 ， 以 及 学 好 PHP 语言 的 方法 等 ， 其 主要 目的 是 让 读 
者 对 PHP 语言 有 一 个 整体 的 了 解 和 认识 ， 然 后 再 循序 渐进 地 学 习 ， 最 后 达到 完全 
事 握 并 精通 PHP 语言 的 目的 。 

通过 阅读 本 章 ， 可 以 学 习 到 : 

PHP 是 什么 
PHP 5 的 新 特性 

PHP 的 语言 优势 

PHP 语言 的 相关 术语 
学 好 PHP 的 方法 

PHP 常用 的 代码 编辑 工具 
了 解 PHP 的 相关 学 习 资 源 


总 理 理 吾 吾 吾 吾 
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1.1 PHP 概述 


1.1.1 PHP 是 什么 


PHP 起 源 于 1995 年 ， 由 Rasmus Lerdorf 开发 。PHP 是 Hypertext Preprocessor( 超 文本 预 处 理 器 ) 
的 缩写 ， 是 一 种 开源 、 跨 平台 、 独 立 于 架构 、 解 释 型 、 面 向 对 象 、 快 速 安全 、 简 单 易学 、 性 能 优越 的 
Web 服务 器 端 动态 网 页 开发 语言 。 目 前 已 有 超过 2200 万 个 网 站 、1.5 万 家 公司 、450 万 程序 开发 人 员 
在 使 用 PHP 语言 ， 它 是 目前 动态 网 页 开发 中 使 用 最 为 广泛 的 语言 之 一 。 


1.1.2 PHP 5 的 新 特性 


PHP 5 中 的 对 象 已 经 进行 了 较 系统 、 较 全 面 的 调整 ， 下 面 着 重 讲述 PHP 5 中 新 的 对 象 模式 。 
(1) PHP 5 采用 全 新 的 内 存 管理 机 制 ， 使 其 在 多 线程 的 环境 下 可 以 更 有 效 地 运行 。 
(2) 在 PHP 5 全 新 的 面向 对 象 模型 中 ， 引 入 了 全 新 的 面向 对 象 机 制 。 

构造 函数 和 析 构 函数 。 

对 象 的 引用 。 

对 象 的 克隆 〈clone) 。 

对 象 中 的 私有 、 公 共 及 受 保 护 模式 (public/private 和 protected 关键 字 ) 。 

接口 〈Interface) 。 

抽象 类 。 

__call。 

_ set 和 _ get。 

(3) 引入 “try…catch” 异 常 处 理 机 制 。 

(4) 全 新 的 XML 支持 。 


办 办 凶 凶 凶 凶 凶 凶 


1.1.3 PHP 的 语言 优势 


PHP 起 源 于 自由 软件 ， 即 开放 源 代 码 软 件 ， 使 用 PHP 进行 Web 应 用 程序 的 开发 具有 以 下 语言 优势 。 

(1) 安全 性 高 : PHP 是 开源 软件 ， 每 个 人 都 可 以 看 到 所 有 PHP 的 源 代码 ， 程 序 代码 与 Apache 编 
译 在 一 起 的 方式 也 可 以 让 它 具 有 灵活 的 安全 设 定 ，PHP 具有 了 公认 的 安全 性 能 。 

(2) 跨 平台 : PHP 几乎 支持 所 有 的 操作 系统 平台 〈 如 Win32 或 UNIX/Linux/Macintosh/FreeBSD/OS2 
等 ) ， 并 且 支 持 Apache、IIS 等 多 种 Web 服务 器 ， 并 以 此 广 为 流 行 。 

(3) 支持 广泛 的 数据 库 : 可 操纵 多 种 主流 与 非 主流 的 数据 库 ， 如 MySQL、Access、SQL Server、 
Oracle、DB2 等 ， 其 中 PHP 与 MySQL 是 现在 最 佳 的 组 合 ， 它 们 的 组 合 可 以 跨 平 台 运 行 。 

(4) 简单 易学 : PHP 嵌入 在 HTML 语言 中 ， 以 脚本 语言 为 主 ， 内 置 丰富 函数 ， 语 法 简单 、 书 写 
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容易 ， 方 便 学 习 掌握 。 

(5) 执行 速度 快 : 占用 系统 资源 少 ， 代 码 执行 速度 快 。 

(6) 开发 成 本 低 : 在 流行 的 企业 应 用 LAMP 平台 中 ，Linux、Apache、MySQL 和 PHP 都 是 免费 
软件 ， 这 种 开源 免费 的 框架 结构 可 以 为 网 站 经 营 者 节省 很 大 一 笔 开 支 。 

(7) 模板 化 : 实现 程序 逻辑 与 用 户 界面 分 离 。 

(8) 支持 面向 对 象 : 支持 面向 对 象 和 过 程 的 两 种 风格 开发 ， 并 可 向 下 兼容 。 面 向 对 象 编程 (OOP) 
是 当前 的 软件 开发 趋势 。PHP 对 OOP 提供 了 良好 的 支持 ， 可 以 使 用 OOP 的 思想 来 进行 PHP 的 高 级 编 
程 ， 这 对 于 提高 PHP 编程 能 力 和 规划 好 Web 开发 架构 都 非常 有 意义 。 

(9) 内 嵌 Zend 加 速 引擎 ， 性 能 稳定 快速 。 

(10) 应 用 范围 广 : PHP 技术 在 Web 开发 的 各 个 方面 应 用 得 非常 广泛 。 世 界 上 很 多 大 公司 都 采用 
了 PHP 技术 ， 如 德意志 银行 的 交易 系统 ， 华 尔 街 的 股票 在 线 买 卖 ， 汉 莎 航 空 公司 的 票务 处 理 ， 甚 至 美 
联储 、 宇 航 局 都 采用 了 PHP 技术 。 


1.1.4 ”PHP 语言 的 发 展 


TIOBE 世界 编程 语言 排行 榜 在 一 定 程度 上 体现 了 编程 语言 在 当前 的 流行 趋势 。TIOBE 最 新 公布 了 
2009 年 3 月 的 编程 语言 排行 榜 ， 除 Java、C、C++ 依 旧 强 势 占据 三 甲 的 位 置 外 ， 前 十 名 的 其 他 语言 排 位 
均 有 小 幅 波 动 。 本 期 值得 关注 的 是 PHP 语言 。 在 本 期 榜 单 中 ，Visual Basic 在 坚守 了 两 个 月 第 四 名 的 位 
置 后 ， 本 期 下 降 一 位 ， 与 上 期 排名 第 五 的 PHP 互 换 位 置 。2009 年 3 月 份 TIOBE 世界 编程 语言 排行 的 
相关 数据 说 明 如 图 1.1 所 示 。 

TIOBE 编程 语言 排行 榜 衡 量 了 各 种 编程 语言 的 流行 程度 。 该 排行 榜 每 月 发 布 一 次 ， 统 计数 据 包括 全 
球 范围 的 软件 工程 师 、 培 训 课 程 以 及 第 三 方 供应 商 ， 数 据 来 自 Google、MSN 和 Yahool 等 流行 搜索 引擎 。 


[加 说 明 : TIOBE 声称 ， 该 排行 榜 并 不 是 要 评选 最 优秀 的 编程 语言 或 是 统计 完成 编程 量 最 大 的 语言 ， 但 
它 可 以 帮助 用 户 了 解 自 己 掌握 的 编程 语言 是 否 跟 得 上 时 代 的 发 展 , 并且 在 开发 新 的 软件 系统 
需要 对 编程 语言 做 策略 性 选择 时 提供 参考 。 


PHP 是 在 1994 年 由 Rasmus Lerdorf 创建 的 , 最 初 只 是 一 个 简单 的 用 Perl 语言 编写 的 统计 他 自己 网 

站 访问 者 数量 的 程序 。 后 来 重新 用 C 语言 编写 , 同时 可 以 访问 数据 库 。1995 年 , Personal Home Page Tools 
(PHP Tools) 开始 对 外 发 表 第 一 个 版 本 ，Rasmus Lerdorf 发 布 了 PHP 1.0。 

此 后 ， 越 来 越 多 的 网 站 开始 使 用 PHP， 并 且 强 烈 要 求 增加 一 些 特性 ， 如 循环 语句 和 数组 变量 等 。 
在 新 的 成 员 加 入 开发 行列 之 后 ，1995 年 的 第 二 版 PHP/FI (Form Interpreter) 加 入 了 对 mSQL 的 支持 ， 
PHP 2.0 的 发 布 ， 确 立 了 PHP 在 动态 网 页 开发 上 的 地 位 。 

到 1996 年 底 ， 有 15000 个 网 站 使 用 PHP/FI。 

到 1997 年 中 ， 使 用 PHP/FI 的 网 站 超过 5 万 个 。 

随 着 PHP 5.0 的 发 布 和 更 多 对 面向 对 象 的 支持 ,PHP 正 不 断 巩固 自己 在 Web 开发 领域 的 王者 地 位 。 

近 几 年 PHP 的 发 展 呈 现 上 升 趋 势 ， 如 图 1.2 所 示 ， 这 也 说 明了 PHP 语言 简单 、 易 学 、 面 向 对 象 和 
安全 等 特点 正在 被 更 多 人 所 认同 。 相 信 新 的 PHP 语言 将 会 朝 着 更 加 企业 化 的 方向 迈进 ， 并 且 将 更 适合 
大 型 系统 的 开发 。 


PHP 开发 实战 宝典 


EEC Dw 
] ao orm% | -00% | a 


图 1.1 2009 年 3 月 TIOBE 世界 编程 语言 排名 图 1.2 PHP 近 几 年 的 语言 走势 图 
[四 说 明 : 图 1.1 和 图 1.2 中 的 数据 摘自 http://www.tiobe.com 网 站 。 


PHP 凭借 其 代码 开源 、 完 全 免费 和 安全 性 高 等 特性 ， 正 吸引 着 越 来 越 多 的 Web 开发 人 员 。 主 流 
PHP 5 的 诞生 、Zend II 引擎 的 采用 ， 面 向 对 象 的 支持 以 及 模板 化 使 得 PHP 编程 进入 了 一 个 新 时 代 ， 用 
户 数量 成 稳步 上 升 趋势 。PHP 凭借 其 强大 的 功能 ， 必 将 呈现 出 良好 的 发 展 前 景 。 

PHP 无 处 不 在 ， 它 可 以 应 用 于 任何 领域 ， 并 且 已 拥有 几 百 万 个 用 户 ， 其 发 展 速度 要 快 于 在 它 之 前 
的 任何 一 种 计算 机 语言 。PHP 能 够 给 企业 和 最 终 用 户 带 来 数 不 尽 的 好 处 。 据 最 新 数据 统计 ， 全 世界 有 
超过 2200 万 的 网 站 和 1.5 万 家 公司 在 使 用 PHP 语言 ， 包 括 百度 、 雅 虎 、Google、YouTube、Digg 等 著 
名 网 站 ， 也 包括 汉 沙 航空 电子 订 票 系统 、 德 意志 银行 的 网 上 银行 、 华 尔 街 在 线 的 金融 信息 发 布 系统 等 ， 
甚至 军队 系统 这 类 苛刻 的 环境 。 除 此 之 外 ，PHP 也 是 企业 用 来 构建 服务 导向 型 、 创 造 和 混合 Web 融 于 
新 一 代 的 综合 性 商业 应 用 的 语言 ， 成 为 开源 商业 应 用 发 展 的 方向 。 


1.2 PHP 与 其 他 语言 的 比较 


就 目前 的 动态 网 页 开发 技术 而 言 ， 除 了 PHP 以外， 还 有 ASP、JSP 和 .NET， 它 们 都 各 有 千秋 ， 都 
有 着 广泛 的 用 户 群 ， 本 节 将 它们 进行 简单 的 比较 ， 如 表 1.1 所 示 。 


表 1.1 PHP 与 其 他 语言 的 比较 
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它们 都 各 有 所 长 ， 可 以 根据 实际 需要 从 中 选择 一 种 。 不 一 定 要 选择 最 好 的 ， 但 一 定 要 选择 最 适合 
自己 的 。 


1.3 PHP 语言 相关 术语 


PHP 不 仅 是 一 门 语言 ， 而 且 已 慢 慢 扩展 成 为 一 种 行业 。 专 业 术 语 的 记忆 有 助 于 对 新 语言 的 学 习 ， 
特别 是 在 阅读 技术 文档 时 ， 能 帮助 理解 文档 中 大 量 的 专业 术语 ， 这 不 仅 能 加 快 学 习 的 进度 ， 也 能 使 用 户 
更 准确 地 理解 原文 的 意思 ， 以 便 在 学 习 过 程 中 少 走 弯路 。 下 面 介绍 这 门 语言 涉及 的 一 些 常 用 行业 术语 。 

回 PHP 

PHP 是 Hypertext Preprocessor ( 超 文 本 预 处 理 器 ) 的 缩写 ， 是 基于 服务 器 端 运行 的 脚本 程序 语言 。 
可 以 实现 数据 库 和 网 页 之 间 的 数据 交互 。 PHP 的 独特 语法 混合 了 C 语言 、Java 语言 和 Perl 语言 的 特点 。 
PHP 语言 可 以 单独 运行 , 也 可 以 嵌入 在 HTML 文件 中 , 这 样 程序 员 就 可 以 不 必 完 全 依赖 HTML 生成 网 
页 。 因 为 PHP 语言 的 执行 都 在 服务 器 端 ， 所 以 在 客户 端 看 不 到 PHP 代码 。 

回 类 

类 是 对 某 个 对 象 的 定义 ， 是 属性 和 方法 的 集合 ， 是 面向 对 象 编程 方式 的 核心 和 基础 ， 通 过 类 可 以 
将 零散 的 用 于 实现 某 项 功能 的 代码 进行 有 效 管理 。 实 际 上 它 本 身 并 不 是 对 象 ， 因 为 它 不 存在 于 内 存 中 。 
当 引 用 类 的 代码 运行 时 ， 类 的 一 个 新 的 实例 〈 即 对 象 ) 就 在 内 存 中 创建 了 。 通 过 类 可 以 在 内 存 中 创建 
多 个 相同 类 型 的 对 象 。 

回 对 象 

对 象 是 类 进行 实例 化 后 的 产物 ， 是 一 个 实体 。 对 象 就 是 类 存在 于 内 存 中 的 实例 。 通 过 对 类 进行 实 
例 化 ， 就 能 得 到 对 应 的 对 象 。 

回 函数 

函数 是 一 段 相 对 独立 的 代码 ,不 同 的 语言 有 不 同 的 定义 方式 。 在 PHP 中 ， 函数 就 是 有 效 的 PHP 代 
码 的 集合 。 在 设计 复杂 程序 时 ， 可 以 把 程序 分 为 几 个 函数 ， 不 同 的 函数 完成 不 同 的 功能 。 其 优点 在 于 
各 部 分 充分 独立 ， 不 仅 可 以 使 程序 易 读 、 易 维护 ， 还 可 以 对 代码 进行 复 用 。 

回 Session 

Session 用 中 文 来 解释 就 是 会 话 期 。 在 计算 机 专业 术语 中 ，Session 是 指 一 个 终端 用 户 与 交互 系统 进 
行 通信 的 时 间 间 隔 ， 通 常 指 从 注册 进入 系统 到 注销 退出 系统 所 经 过 的 时 间 。 因 此 ，Session 实际 上 是 一 
个 特定 的 时 间 概 念 。Session 是 将 Session 的 信息 保存 在 服务 器 上 , 并 通过 一 个 Session ID 来 传递 客户 端 
的 信息 。 服 务 器 在 接收 到 Session ID 后 根据 这 个 ID 来 提供 相关 的 Session 信息 资源 。 由 于 Session 为 服 
务 器 存储 ， 远 程 用 户 没 办 法 修改 Session 文件 的 内 容 。 
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回 Cookie 

Cookie 是 一 种 在 远程 浏览 器 端 储存 数据 并 以 此 来 跟踪 和 识别 用 户 的 机 制 。 简 单 地 说 ，Cookie 是 
Web 服务 器 暂时 存储 在 用 户 硬 盘 上 的 一 个 文本 文件 ， 并 随后 被 Web 浏览 器 读 取 。 在 PHP 中 通过 
setcookie() 函 数 创 建 Cookie。 在 创建 Cookie 之 前 ， 首 先 必须 了 解 的 是 ，Cookie 是 HTTP 头 标的 组 成 部 
分 , 而 头 标 必须 在 页 面 其 他 内 容 之 前 发 送 , 它 必须 最 先 输出 ， 即 使 在 setcookie0 函 数 前 输出 一 个 HTML 
标记 或 echo 语句 ， 甚 至 一 个 空 行 都 会 导致 程序 出 错 。 

加 常量 

常量 ， 即 不 可 变 的 数值 或 数据 项 。 常 量 的 值 通常 是 在 程序 运行 前 定义 的 ， 在 整个 程序 运行 的 过 程 
中 ， 其 值 是 不 会 改变 的 。 一 个 常量 由 英文 字母 、 下 划 线 和 数字 组 成 ， 但 数字 不 能 作为 首 字母 出 现 。 常 
量 默认 为 大 小 写 敏 感 。 按 照 惯例 ， 常 量 标识 符 总 是 大 写 的 。 

回 变量 

和 很 多 语言 不 同 ， 在 PHP 中 使 用 变量 之 前 不 需要 声明 变量 (PHP 4 之 前 需要 声明 变量 ) 。PHP 中 
的 变量 用 一 个 美元 符号 “$” 后 面 跟 变 量 名 来 表示 。PHP 中 的 变量 名 是 区 分 大 小 写 的 。 

回 引用 

在 PHP 中 引用 就 是 用 不 同 的 名 字 访 问 同一 个 变量 内 容 。 变 量 名 和 变量 内 容 是 不 一 样 的 ， 因 此 同样 
的 内 容 可 以 有 不 同 的 名 字 。 

回 构造 函数 

构造 函数 又 称 为 构造 器 ， 是 类 中 的 一 个 特殊 函数 。 在 PHP 5 中 ， 构 造 函数 使 用 统一 的 名 称 
“_construct” 进 行 声明 。 在 使 用 new 操作 符 创建 对 象 时 ， 构 造 函 数 将 会 被 自动 调用 。 如 果 一 个 类 没 
有 构造 函数 ， 则 调用 基 类 的 构造 函数 ， 如 果 有 则 调用 当前 类 构造 函数 。 一 般 用 于 在 创建 对 象 时 进行 初 
始 化 操作 。 

回 析 构 函数 

PHP 5 引入 了 析 构 函数 的 概念 ， 通 过 定义 “ destruct” 函 数 来 建立 析 构 函数 。 析 构 函 数 与 构造 函数 
的 功能 正好 相反 ， 它 用 于 销毁 对 象 。 析 构 函 数 会 在 到 某 个 对 象 的 所 有 引用 都 被 删除 或 者 当 对 象 被 显 式 
销毁 时 执行 。 

在 PHP 语言 的 学 习 过 程 中 ， 读 者 应 该 加 强 对 PHP 专业 术语 和 其 他 通用 专业 术语 的 学 习 和 积累 。 


1.4 资深 程序 员 谈 如 何 学 习 PHP 


怎样 学 好 PHP 语言 ， 这 是 所 有 PHP 程序 员 都 会 考虑 的 问题 。 其 实 ， 每 种 语言 的 学 习 方 法 都 大 同 小 
异 ， 相 信 大 家 选择 PHP 语言 并 不 是 因为 它 的 背景 和 悠久 历史 ， 更 重要 的 是 它 的 实用 性 。 
下 面 是 笔者 结合 多 年 的 开发 实践 所 总 结 出 来 的 学 习 经 验 ， 与 所 有 PHP 程序 开发 者 分 享 : 
(1) 熟悉 HTML/CSS/JavaScript 等 网 页 基本 元 素 ， 完 成 阶段 可 自行 制作 完整 的 网 页 ， 对 元 素 属性 
达到 熟悉 程度 。 
(2) 学 会 配置 PHP 的 开发 环境 ， 并 选择 一 种 适合 自己 的 开发 工具 。 
(3) 理解 动态 语言 的 概念 ， 运 作 机 制 ， 熟 悉 PHP 语法 。 
(4) 学 习 如 何 将 PHP 与 HTML 结合 起 来 完成 简单 动态 页 面 。 


第 1 章 初 识 PHP 


(5) 接触 MySQL 数据 库 ， 开 始 设计 数据 库 方面 的 程序 。 

(6) 不 断 巩 固 ， 熟 练 使 用 大 部 分 PHP 常用 函数 ， 并 理解 OOP，MySQL 优化 ， 以 及 模板 。 

(7) 开发 一 个 功能 齐全 的 动态 站 点 。 

这 套 学 习 方案 是 一 个 循序 渐进 的 过 程 ， 初 学 者 不 要 看 到 上 面 的 短 短 几 行文 字 就 以 为 学 习 起 来 很 简 
单 ， 任 何 技术 其 实 都 不 简单 ， 即 使 是 小 吃 部 的 美味 菜 看 也 不 是 一 下 子 就 能 做 成 的 。 

下 面 解释 一 下 这 个 学 习 过 程 。 

任何 网 站 都 是 由 网 页 组 成 的 ， 也 就 是 说 想 完成 网 站 ， 必 须 先 学 会 做 网 页 ， 因 此 必须 要 掌握 HTML 
语言 ， 才 能 为 今后 制作 网 站 打下 基础 。 ec nse dee icc 

在 学 习 HTML、CSS 和 JavaScript 的 过 程 中 ， 边 学 边 做 是 最 有 效 的 方式 ， 当 然 这 一 方式 对 于 学 习 
PHP 同样 是 最 有 效 的 。HTML 中 的 任何 元 素 都 要 亲自 实践 ， 只 有 熟悉 各 个 元 素 的 效果 之 后 ， 才 会 记忆 
深刻 ， 而 对 于 书本 中 的 知识 只 是 一 味 地 死记 硬 背 是 绝对 不 行 的 。 大 部 分 新 手 之 所 以 觉得 概念 难 学 ， 大 
部 分 是 因为 “懒惰 ”， 懒 惰 是 阻止 一 个 人 走向 成 功 的 最 大 敌人 ， 所 以 克服 懒惰 的 习惯 ， 才 能 更 快 地 学 
好 一 门 语言 。 

另外 ， 扎 实 的 基础 对 于 一 个 程序 员 来 说 尤为 重要 ， 学 习 知 识 切 记 不 可 急于 求 成 ， 必 须要 打 好 基础 ， 
再 进 阶 学 习 有 一 定 难度 的 技术 ， 才 能 轻松 地 开发 网 站 。 而 那些 不 重视 “地 基 ”， 一 心 要 打造 “空中 楼 
阁 ”的 程序 员 又 怎 能 开发 出 好 的 网 络 程序 呢 ? 所 以 ， 建 议 读者 多 阅读 一 些 基 础 教材 ， 了 解 基 本 的 编程 
知识 。 

在 熟悉 了 HTML/CSS/JavaScript 等 网 页 基本 元 素 后 ， 就 要 开始 接触 PHP 了， 首先 需要 做 的 就 是 搭 
建 PHP 环境 和 选择 一 款 开发 工具 。 

搭建 PHP 环境 的 方法 有 很 多 ， 可 以 自 定 义 安装 Apache 服务 器 、MySQL 服务 器 和 PHP， 然 后 手动 
配置 环境 。 但 是 对 于 新 手 来 说 ， 最 简单 的 方法 就 是 使 用 集成 化 安装 包 ， 因 为 集成 化 安装 包 操 作 起 来 非 
常 方便 ， 可 以 直接 安装 Apache 服务 器 、MySQL 服务 器 、PHP 和 phpMyAdmin， 而 且 不 需要 用 户 手动 
配置 ， 安 装 完 以 后 即 可 直接 使 用 。 像 这 种 集成 化 安装 包 网 络 上 非常 多 ， 如 使 用 AppServ 集成 化 安装 包 
(第 2 章 有 详细 介绍 ) 。 

PHP 的 编辑 工具 有 很 多 ， 每 款 编辑 工具 都 有 其 各 自 的 优势 。 在 编写 程序 时 ， 一 款 好 的 编辑 工具 会 
使 程序 员 编 写 过 程 更 加 轻松 、 有 效 和 快捷 , 达到 事半功倍 的 效果 。 在 本 章 1.5 节 中 推荐 了 几 款 开发 工具 ， 
读者 可 以 结合 自己 的 需求 进行 选择 。 

在 理解 了 HIML， 并 熟悉 了 PHP 的 概念 和 语法 后 ， 进 行 PHP 和 HTML 混合 编程 应 该 不 成 问题 
在 此 期 间 ， 可 以 用 PHP 为 自己 设计 一 个 漂亮 的 页 面 ， 然 后 在 浏览 器 上 输出 此 时 此 刻 最 想 说 的 话 ， 不 要 
觉得 幼稚 ， 虽 然 你 输入 的 是 一 小 段 代 码 ， 但 是 对 于 你 的 编程 之 路 ， 可 是 迈 出 了 整整 一 大 步 。 

在 高 兴 之 余 就 必须 继续 努力 了 ， 学 习 PHP 与 数据 库 的 操作 。MySQL 数据 库 可 谓 是 PHP 的 黄金 拱 
档 。 等 到 你 发 奋 努 力学 会 了 用 PHP 成 功 地 添加 、 修 改 、 删 除数 据 时 ， 显 然 距离 成 功 已 经 指日可待 了 。 
巩固 了 自己 的 知识 ， 熟 悉 了 PHP 和 MySQL 开发 的 要 领 之 后 ， 开 发 一 个 留言 本 ， 实 现 一 个 计数 器 ， 你 
就 能 充分 体会 到 成 就 感 了 。 

此 时 往往 是 程序 员 能 否 精通 PHP 的 关键 ， 为 什么 这 么 说 呢 ? 因为 很 多 程序 员 当 发 现 自己 可 以 做 很 
多 例子 ,可 以 动态 操作 数据 库 时 , 就 以 为 学 会 了 PHP、 精 通 了 PHP。 其实 , 还 早 呢 ! 你 还 没有 接触 PHP 
ore het dh 这 时 候 要 不 懈 努 力 ， 一 一 去 接触 这 些 技 术 ， 精 通 这 些 技术 

， 你 会 发 现 ，PHP 的 应 用 是 如 此 的 广泛 
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总 而 言 之 ，PHP 的 不 断 升 级 会 让 你 有 学 不 完 的 新 技术 ， 这 里 可 以 用 学 无 止境 来 形容 学 习 PHP 的 过 
程 。 另 外 ， 学 习 PHP 还 有 一 个 重点 中 的 重点 一 一 学 习 编 码 规范 ， 以 此 来 养 成 一 个 良好 的 编程 习惯 。 

在 学 习 PHP 的 过 程 中 ， 会 接触 到 大 量 的 函数 ，PHP 的 函数 有 上 千 种 ， 下 载 一 个 PHP 中 文 手册 和 
MySQL 手册 ， 或 者 身边 备 上 一 两 本 PHP 函数 类 的 相关 书籍 ， 就 可 以 快速 提高 编程 效率 ， 解 决 程序 中 
的 异常 ， 使 其 成 为 你 的 编程 助手 。 

其 实 ， 学 习 任 何 一 门 语言 就 是 一 个 多 实践 ， 多 思考 ， 多 请 教 的 过 程 。 不 要 死记 语法 ， 特 别 是 对 于 
刚 接触 PHP 语言 的 程序 员 ， 掌 握 好 基本 语法 ， 反 复 实 践 ， 仅 能 读 懂 书 本 中 的 内 容 和 技术 是 不 行 的 ， 必 
须 动手 编写 程序 代码 ， 并 运行 程序 、 分 析 运 行 结构 ， 让 大 脑 对 学 习 内 容 有 个 整体 的 认识 和 肯定 ， 用 自 
己 的 方式 去 思考 问题 ， 编 写 代码 来 提高 编程 思想 。 平 时 多 借鉴 网 上 一 些 好 的 功能 模块 ， 培 养 自 己 的 编 
程 思想 ; 多 向 他 人 请 教 ， 学 习 他 人 的 编程 思想 ; 多 与 他 人 沟通 技术 问题 ， 提 高 自己 的 技术 和 见识 ， 这 
样 可 以 快速 地 进入 学 习 状 态 。 借 鉴别 人 成 功 的 代码 ， 绝 对 是 有 益 无 害 ， 因 为 多 研究 那些 经 过 千 锤 百 炼 
的 经 典 代码 ， 是 提高 编程 水 平 的 最 好 方法 。 另 外 ， 目 前 很 多 PHP 书籍 都 配 有 视频 录像 ， 可 以 看 一 些 典 
型 的 视频 录像 ， 从 而 了 解 他 人 的 编程 思想 ， 快 速 提高 自身 的 编程 水 平 。 

学 一 门 技 术 最 忌 急躁 ， 不 能 遇 到 技术 问题 就 放 齐 。 遇 到 问题 必须 冷静 对 待 ， 不 要 让 自己 的 大 脑 思 
绪 紊 乱 ， 保 持 清 醒 的 头脑 才能 分 析 和 解决 各 种 问题 。 可 以 尝试 听 歌 、 散 步 、 玩 游戏 等 活动 放松 自己 。 
另外 还 要 尝试 自己 解决 ， 这 样 可 以 提高 自己 的 程序 调试 能 力 ， 并 能 提高 解决 常见 问题 的 能 力 。 

学 习 PHP 不 仅 要 掌握 方法 , 更 多 的 是 付出 汗水 ; 同时 不 能 轻 言 放弃 ， 相 信 自己 ， 相 信 自 己 的 选择 ， 
更 要 相信 自己 的 能 力 ， 如 果 自 己 想 放 弃 ， 不 如 想 想 这 句 话 一 一 努力 不 一 定 成 功 ， 但 放弃 必定 失败 ! 

最 后 要 叮嘱 各 位 的 是 一 一 抵御 诱惑 。 本 章 1.2 节 中 讲解 的 PHP/ASP/JSP/.NET 的 对 比 也 许 会 让 你 无 
所 适 从 ， 你 也 许 学 了 一 半 PHP， 又 开始 打 .NET 的 主意 ,或 者 有 人 说 Java 很 强 ， 这 个 时 候 绝对 不 能 动 
摇 ， 要 明确 自己 的 学 习 目 标 和 方向 ,选择 并 锁定 一 门 语言 ， 按 照 自己 的 既定 目标 努力 学 习 和 认真 研究 
直到 精通 。 切 记 不 要 哪 门 都 学 ， 哪 门 都 不 精 。 哪 怕 你 真 想 学 ， 也 得 学 会 了 PHP， 然 后 再 学 。 见 异 思 迁 
是 最 不 可 取 的 ， 狗 能 狂 玉 米 就 是 这 个 道理 ， 如 果 经 常 中 途 放 弃 ， 只 能 是 一 无 所 获 ， 还 浪费 了 宝贵 的 时 
间 和 经 历 ， 得 不 偿 失 。 

因此 ， 必 须要 强迫 自己 完成 自己 的 目标 ， 要 有 坚持 不 懈 、 持 之 以 恒 的 精神 。 精 通 一 门 语言 就 是 这 
么 坚持 下 来 的 。 


1.5 常用 代码 编辑 工具 


PHP 的 开发 工具 很 多 ， 每 种 开发 工具 都 有 其 各 自 的 优势 。 在 编写 程序 时 ， 一 款 好 的 编辑 工具 会 使 
程序 员 的 编写 过 程 更 加 轻松 、 有 效 和 快捷 ， 达 到 事半功倍 的 效果 。 因 此 读者 可 根据 自己 的 需求 有 选择 
性 地 使 用 开发 工具 。 

对 于 一 款 好 的 代码 编辑 工具 ， 除 了 具备 最 基本 的 代码 编辑 功能 外 ， 一 个 必 备 的 功能 就 是 语法 的 高 
亮 显示 。 应 用 语法 的 高 亮 显示 ， 可 以 对 代码 中 的 不 同 元 素 采用 不 同 的 颜色 进行 显示 ， 如 关键 字 用 蓝 色 、 
对 象 方法 用 红色 标识 等 。 另 外 ， 一 款 好 的 代码 编辑 工具 应 具备 格式 排版 功能 ， 格 式 排版 功能 可 以 使 程 
序 代码 的 组 织 结构 清晰 易 懂 ， 并 且 易 于 程序 员 进行 程序 调试 ， 排 除 程序 的 错误 异常 。 

下 面 介绍 几 款 常用 的 代码 编辑 工具 。 
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回 Macromedia Dreamweaver 

Macromedia Dreamweaver 是 一 款 专 业 的 网 站 开发 编辑 器 。 它 将 可 视 布 局 工具 、 应 用 程序 开发 功能 
代码 编辑 支持 组 合 在 一 起 ， 其 功能 强大 ， 使 得 各 个 层次 的 开发 人 员 和 设计 人 员 都 能 够 快速 创建 出 吸引 人 的 、 
标准 的 网 站 和 应 用 程序 。 它 采 用 了 多 种 先进 的 技术 , 能 够 快速 高 效 地 创建 极 具 表现 力 和 动感 效果 的 网 页 ， 
使 网 页 创作 过 程 简单 无 比 。 同 时 ，Macromedia Dreamweaver 提供 了 代码 自动 完成 功能 ， 不 但 可 以 提高 
编写 速度 ， 而 且 减 少 了 错误 代码 出 现 的 几率 。Macromedia Dreamweaver 既 适 用 于 初学 者 制作 简单 的 网 
页 ， 又 适用 于 网 站 设计 师 、 网 站 程序 员 开发 各 类 大 型 应 用 程序 ， 极 大 地 方便 了 程序 员 对 网 站 的 开发 与 
维护 。 

Macromedia Dreamweaver 从 MX 版 本 开始 支持 PHP+MySQL 的 可 视 化 开发 ， 对 于 初学 者 确实 是 比 
较 好 的 选择 ， 因 为 如 果 是 一 般 性 开发 ， 几 乎 是 可 以 不 用 一 行 代码 也 可 以 写 出 一 个 程序 ， 而 且 都 是 所 见 
即 所 得 的 。 所 包含 的 特征 包括 : 语法 加 亮 、 函 数 补 全 ， 形 参 提示 、 全 局 查找 替换 、 处 理 Flash 和 图 像 编 
辑 等 。 同 时 ， 可 以 为 PHP、ASP 等 脚本 语言 提供 辅助 支持 。 

另外 ，Macromedia Dreamweaver 从 第 8 版 开始 ， 提 供 代码 折 县 功能 ， 可 以 将 一 个 代码 块 ， 如 一 个 
方法 或 者 一 个 类 的 代码 块 折 登 起 来 用 两 行 代替 ， 需 要 时 可 以 再 展开 。 

下 载 地 址 : http:/www.adobe.com/downloads/。 


< 的 注意 : Macromedia Dreamweaver MX 是 首选 的 网 页 开发 工具 。 本 书 所 介绍 的 网 页 和 实例 都 是 使 用 


Macromedia Dreamweaver 8 编辑 的 。 


回 Eclipse 

Eclipse 是 一 款 支 持 各 种 应 用 程序 开发 工具 的 编辑 器 ， 为 程序 设计 师 提供 了 许多 强悍 的 功能 。 它 支 
持 多 语言 的 关键 字 和 语法 加 亮 显示 ， 支 持 查询 结果 匹配 部 分 在 编辑 器 中 的 加 亮 显 示 ， 支 持 代码 格式 化 
功能 ， 还 具备 强大 的 调试 功能 ， 可 以 设置 断 点 ， 使 用 单 步 执 行 方法 执行 源 代码 。 

官方 网 站 : http://www.eclipse.org。 

回 ZendStudio 

ZendStudio 是 目前 公认 的 最 强大 的 PHP 开发 工具 ， 具 备 功 能 强大 的 专业 编辑 工具 和 调试 工具 ， 包 
括 编辑 、 调 试 、 配 置 PHP 程序 所 需要 的 客户 及 服务 器 组 件 ， 支 持 PHP 语法 加 亮 显 示 ， 尤 其 是 功能 齐全 
的 调试 功能 ， 让 PHP 错误 不 再 可 怕 。ZendStudio 是 一 款 收费 软件 ， 不 过 可 以 免费 下 载 试 用 版 。 

下 载 地 址 : http://www.zend.com/store/products/zend-studio.php。 

回 PHPEdit 

PHPEdit 是 一 款 Windows 操作 系统 下 优秀 的 PHP 脚本 IDE (集成 开发 环境 ) 。 该 软件 为 快速 、 便 
捷 地 开发 PHP 脚本 提供 了 多 种 工具 ， 其 功能 包括 : 语法 关键 词 高 亮 , 代码 提示 、 浏 览 ， 集成 PHP 调试 
工具 ; 帮助 生成 器 ; 自 定 义 快捷 方式 ，150 多 个 脚本 命令 ; 键盘 模板 ; 报告 生成 器 ; 快速 标记 ; 插件 等 。 

官方 网 站 : http://phpedit.svoi.net。 

回 UltraEdit 

UltraEdit 是 能 够 满足 用 户 一 切 编辑 需要 的 编辑 器 。UltraEdit 是 一 套 功能 强大 的 文本 编辑 器 ， 可 以 
编辑 文本 、 十 六 进 制 、ASCI 码 ， 可 以 取代 记事 本 程序 ， 内 建英 文 单字 检查 、C++ 及 VB 指令 突显 ， 可 
同时 编辑 多 个 文件 ， 而 且 即 使 开启 很 大 的 文件 速度 也 不 会 变 慢 。 软 件 附 有 HTML 标签 颜色 显示 、 搜 寻 
蔡 换 以 及 无 限制 的 还 原 功能 ， 用 户 喜 欢 用 其 来 修改 EXE 或 DLL 文件 。 
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官方 网 站 : http://www.ultraedit.com.cn。 
1.6 学 习 资 源 


人 能 4 视频 讲解 ， 光盘 \TM\Video\1\PHP 的 学 习 资源 .exe 
作为 一 种 被 广泛 使 用 的 Web 应 用 开发 语言 ，PHP 有 着 极其 丰富 的 学 习 资 源 。 


1.6.1 PHP 参考 手册 


学 习 PHP 语言 , 在 电脑 中 必须 配备 一 个 PHP 参考 手册 , 就 像 在 学 习 汉字 时 , 身边 必须 配备 一 本 《新 
华 字典 》 一 样 。 因 为 PHP 参考 手册 是 PHP 语言 的 “新 华 字 典 ”， 它 对 PHP 的 函数 进行 了 详细 的 讲解 
和 说 明 ， 并 且 还 给 出 了 一 些 简单 的 示例 ， 同 时 还 对 PHP 的 安装 与 配置 、 语 言 参考 、 安 全 和 特点 等 一 些 
信息 进行 了 介绍 。 

在 PHP 的 http:/www.php.net/docs.php 网 站 上 ， 提 供 了 PHP 的 各 种 语言 、 格 式 和 版 本 的 PHP 参考 
手册 ， 用 户 可 以 进行 在 线 阅读 ， 也 可 以 打包 下 载 。 

PHP 参考 手册 不 但 对 PHP 的 函数 进行 了 解释 和 说 明 ， 而 且 还 提供 了 快速 查找 的 方法 ， 让 用 户 可 以 
更 加 方便 地 查找 到 指定 的 函数 。PHP 参考 手册 (下 载 版 》 的 运行 效果 如 图 1.3 所 示 。 
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种 义 一 个 字条 当 于 _ mysql_query 
振 寺 集中 他 必 一 行 作为 艾 阿 三 得 ， 下 路 字数 极 ， 只 二 知 革 有 | 
集中 取 尾 一 全 作为 下 数 机 


图 1.3 PHP 参考 手册 
1.6.2 PHP 学 习 讨 论 


回 PHP 的 官方 网 站 http://www.php.net) 

提供 PHP 各 版 本 的 下 载 ， 以 及 PHP 手册 下 载 。 

回 喜悦 国际 村 (http://www.phpx.com) 

目前 国内 最 火爆 的 PHP 讨论 社区 ， 注 册 用 户 数 万 ，PHP 版 面 讨论 激烈 ，PHP 高 级 工程 师 众多 。 
回 PHP 5 研究 室 (http://www.phpv.net) 

关注 新 技术 的 研究 和 跟踪 ， 能 够 了 解 新 技术 ， 同 时 能 够 查询 到 最 新 版 本 的 手册 。 
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加 PHPChina (http:/www.phpchina.comy) 

PHPChina 开源 社区 ， 有 非常 多 的 PHP 源码 ， 能 够 从 中 获取 最 新 的 PHP 信息 资源 。 

Linux 和 UNIX 中 文 网 站 (http://www.chinaunix.net) 

全 球 最 大 的 Linux 和 UNIX 中 文 网 站 ， 其 中 的 PHP 版 块 资料 极其 丰富 。 

回 PHPWind (http://www.phpwind.com) 

PHPWind 论坛 ， 是 国内 发 展 最 迅速 的 论坛 ， 代 码 质量 比较 高 ， 执 行 速度 快 。 

加 Discuz! (http://www.discuz.com/) 

国内 最 著名 的 PHP 论坛 ， 速 度 快 、 稳 定性 好 、 安 全 。 易 于 定制 ， 能 够 支持 非常 多 的 在 线 人 数 。 目 
前 该 论坛 已 彻底 免费 。 


1.7 成 功 案 例 


目前 ， 互 联网 上 很 多 网 站 的 开发 都 是 通过 PHP 语言 来 完成 的 ， 如 搜狐 、 网 易 和 百度 等 ， 在 这 些 知 
名 网 站 的 创作 开发 中 都 应 用 到 了 PHP 语言 。 

吉林 省 明日 科技 有 限 公 司 软件 网 、 图 书 网 、 网 络 学 院 、 编 程 词典 网 等 也 都 是 用 PHP 语言 来 完成 的 。 
感 兴趣 的 读者 可 以 登录 下 面 的 网 站 , 不 但 可 以 浏览 完全 由 PHP 开发 的 网 站 , 体会 PHP 语言 的 强大 功能 ， 
同时 也 可 以 通过 网 站 与 我 们 进行 交流 、 互 相 学 习 ， 也 可 以 更 深入 地 了 解 明 日 科技 ， 了 解 我 们 的 编程 词 
典 ， 了 解 我 们 的 网 络 学 院 。 

吉林 省 明日 科技 有 限 公 司 的 图 书 网 网 址 是 http://www.mingribook.com， 如 图 1.4 所 示 。 

吉林 省 明日 科技 的 网 络 学 院 的 网 址 是 http:/www.cccxy.com， 如 图 1.5 所 示 。 
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图 1.4 明日 科技 图 书 网 首页 图 1.5 明日 网 络 学 院 网 站 首页 


吉林 省 明日 科技 的 论坛 网 网 址 是 http://www.mingribook.com/bbs/bbs_index.php， 如 图 1.6 所 示 。 
吉林 省 明日 科技 的 编程 词典 网 的 网 址 是 http://www.mrbccd.com/index.shtml， 如 图 1.7 所 示 。 
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图 1.6 明日 科技 论坛 网 首页 图 1.7 明日 科技 编程 词典 服务 网 首页 
1.8 本 章 小 结 


本 章 重点 讲述 了 什么 是 PHP，PHP 的 语言 优势 以 及 应 用 领域 ， 详 细 介 绍 了 PHP 5 的 新 特性 ， 通 过 
这 些 内 容 使 读者 对 PHP 有 一 个 全 面 的 认识 。 其 次 ， 指 导读 者 学 习 PHP 的 方法 。 另外， 本 章 的 最 后 还 介 
绍 了 常用 代码 编辑 工具 、 网 络 上 的 学 习 资 源 以 及 一 些 经 典 的 PHP 成 功 案例 ， 以 方便 读者 更 好 地 学 习 
PHP。 
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PHP 环境 搭建 
(en 视频 讲解 : 80 分 钟 ) 


PHP 是 全 球 最 善 及 、 应 用 最 广泛 的 互联 网 开发 语言 之 一 。 学 习 任 何 一 门 编程 语 

言 ， 在 开始 学 习 之 前 都 要 首先 学 会 搭建 和 熟悉 开发 环境 ， 本 章 将 介绍 两 种 操作 系统 
(Windows 和 Linux) 下 的 Apache 服务 器 、My9SQL 服务 器 及 PHP 的 安装 和 配置 

方法 。 另 外 还 特别 为 初学 者 介绍 一 种 简化 安装 和 配置 PHP 环境 的 组 合 包 。 最 后 ， 
使 用 Macromedia Dreamweaver 8 开发 PHP 第 一 个 实例 。 

通过 阅读 本 章 ， 可 以 学 习 到 : 
如 何在 Windows/Linux 下 安装 和 配置 Apache 服务 路 
如 何在 Windows/Linux 下 安装 和 配置 MySQL 服务 路 
如 何在 Windows/Linux 下 安装 PHP 
如 何 使 用 组 合 包 快速 搭建 PHP 环境 
如 何 应 用 开发 工具 编写 、 发 布 和 运行 第 一 个 PHP 程序 
如 何 独 立 解决 常见 的 PHP 环境 安装 问题 


总 理 吾 吾 理 理 


PHP 开发 实战 宝典 


2.1 搭建 PHP 开发 环境 的 准备 工作 


2.1.1 在 Windows 下 搭建 PHP 开发 环境 的 准备 工作 


在 Windows 下 搭建 PHP 与 安装 其 他 的 一 些 软件 工具 不 同 。 因 为 PHP 是 从 Linux 移植 过 来 的 一 种 
语言 ,不 仅 在 开发 环境 上 尽量 保留 着 Linux 的 特点 (Apache 是 Linux 下 的 Web 服务 器 ,地 位 就 像 Windows 
下 的 HS，MySQL 也 是 Linux 系统 中 捆绑 的 数据 库 ) ， 在 安装 上 也 被 烙 上 了 Linux 印记 。 除 了 正常 的 
安装 操作 外 ， 还 需要 在 各 自 的 配置 文件 (.ini、.conf) 中 进行 专门 的 设置 。 

安装 之 前 要 准备 的 安装 包 有 : 

回 Apache 2.2.8-win32-x86-no_sslmsi。 下 载 地 址 为 http://httpd.Apache.org/download.cgi。 

回 ”php-5.2.5-Win32.zip。 下 载 地 址 为 http://www.php.net/downloads.php。 

回 “ mysql-essential-5.0.51a-win32.msi。 下 载 地 址 为 http:/www.mysqlLcom/download/ (下 载 MySQL 

需要 注册 一 个 账号 ) 。 


2.1.2 在 Linux 下 搭建 PHP 开发 环境 的 准备 工作 


在 Linux 下 搭建 PHP 环境 比 Windows 下 要 复杂 得 多 。 除 了 Apache、PHP 等 软件 外 ， 还 要 安装 一 
些 相关 工具 ， 设 置 必要 的 参数 。 而 且 ， 要 使 用 PHP 扩展 库 ， 还 要 进行 编译 。 如 本 书 中 使 用 到 的 SOAP、 
MHASH 等 扩展 库 。 这 里 给 出 在 Linux 下 安装 的 必要 步骤 。 如 果 用 户 在 安装 过 程 中 遇 到 特殊 的 问题 ， 还 
需要 翻阅 Linux 相关 的 书籍 、 手 册 。 

安装 之 前 要 准备 的 安装 包 有 : 
httpd-2.2.8.tar.gz。 下 载 地 址 为 http://www.apache.org。 
php-5.2.5.tar.gz。 下 载 地 址 为 http://www.php.net/downloads.php。 
mysql-5.0.51a-Linux-i686.tar.gz。 下 载 地 址 为 http://www.mysql.com。 
libxml2-2.6.26.tar.gz。 可 在 网 络 上 直接 搜索 该 版 本 进行 下 载 。 


办 办 


2.2 Apache 服务 器 的 安装 和 配置 


2.2.1 在 Windows 下 安装 Apache 服务 器 


使 m 视频 讲解 :光盘 \TM\VideoW2\ 在 Windows 下 安装 Apache 服务 器 .exe 

Apache 服务 器 是 全 球 范围 内 使 用 范围 最 广 的 Web 服务 软件 ， 超 过 50% 的 网 站 都 在 使 用 Apache 服 
务 器 ， 它 以 其 高 效 、 稳 定 、 安 全 、 免 费 〈 最 重要 的 一 点 ) 的 优势 成 为 了 最 受 欢迎 的 服务 器 软件 。 

本 节 主 要 介绍 如 何在 Windows 操作 系统 中 安装 和 配置 Apache 服务 器 。 安 装 Apache 服务 器 前 ， 应 
到 官方 网 站 http://www.apache.org 下 载 Apache 的 安装 程序 Apache 2.2.8-win32-x86-no_ssl.msi。 
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在 Windows 下 安装 和 配置 Apache 服务 器 的 操作 步骤 如 下 。 

(1) 双击 Apache 2.2.8-win32-x86-no_ssl.msi 文件 ， 弹 出 欢迎 页 面 。 单 击 Next 按钮 ， 进 入 到 许可 
协议 页 面 。 

(2) 在 许可 协议 页 面 ， 用 户 需要 同意 页 面 中 的 条 款 才能 继续 安装 。 选 中 I accept the terms in the 
license agreement 单 选 按钮 ， 页 面 如 图 2.1 所 示 。 单 击 Next 按钮 进入 到 下 一 页 面 。 

(3) 本 页 面 是 对 该 程序 的 一 个 描述 和 说 明 。 在 了 解 了 相关 的 信息 后 , 单 击 Next 按钮 进入 到 Server 
Information 页 面 。 

(4) Server Information 页 面 需要 用 户 填写 域名 、 服 务 器 名 称 和 管理 员 Email。Server Information 
页 面 的 填写 效果 如 图 2.2 所 示 。 该 页 面 还 有 两 个 单 选 按钮 ， 如 果 选 中 默认 的 第 一 个 单 选 按钮 ， 说 明 该 服 
务 器 对 所 有 人 开放 ， 并 且 服 务 器 的 端口 号 为 80， 这 个 是 推荐 选项 。 第 二 个 单 选 按钮 是 指 该 服务 器 仅 对 当前 
用 户 开 放 ， 并 且 服 务 器 端口 为 8080。 这 里 选中 第 一 个 单 选 按钮 。 然 后 单 击 Next 按钮 进入 下 一 个 页 面 。 


Vorsion 20,January 2004 
apm apachearghcenses 
TERMS AND cowomons FoR USE REPROOUCTIONM, AND DISTRISUTION 
| Dotntone 
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< i 

图 2.1 许可 协议 页 面 图 2.2 Server Information 页 面 
< 拉 注意 : 如 果 用 户 的 机 器 安装 有 “Internet 信息 服务 (IIS ) 管理 器 "， 那 么 必须 将 此 项 服务 停止 ， 因 
为 IIS 服务 器 的 默认 端口 号 为 80， 同 Apache 服务 器 默认 端口 号 相同 。 如 果 IS 服务 不 停止 ， 

就 会 和 Apache 服务 器 的 端口 号 产生 冲突 ，Apache 服务 器 将 不 能 成 功 安装 。 
(5) 如 图 2.3 所 示 页 面 用 于 选择 安装 类 型 。 安 装 类 型 分 为 典型 安装 和 自 定义 安装 ， 通 常 保持 默认 

选项 即 可 。 单 击 Next 按钮 ， 进 入 到 路 径 选 取 页 面 。 

(6) 在 路 径 选 取 页 面 中 ， 单 击 Change 按钮 可 以 选择 安装 路 径 。 这 里 路 径 设 为 “D:\Apache2.2\”， 
如 图 2.4 所 示 。 
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图 2.3 选择 安装 类 型 图 2.4 指定 路 径 
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(7) 单 击 Next 按钮 进入 文件 安装 页 面 。 这 是 Apache 安装 的 最 后 一 步 ， 程 序 开 始 安装 文件 。 安 装 
结束 后 ， 单 击 Finish 按钮 结束 安装 程序 。 

(8) 安装 完成 后 ，Apache 服务 器 会 自动 开启 。 在 系统 托盘 区 域 将 出 现 一 个 图 标 ， 当 前 Apache 服 
务 启动 时 ， 图 标 样式 为 写 ， 服 务 器 未 启动 时 ， 图 标 样式 为 写 。 

单 击 Apache 服务 器 的 启动 小 图 标 , 将 会 看 到 服务 器 的 开启 与 关闭 功能 ; 也 可 以 用 鼠标 右键 单 击 小 图 
标 ， 在 弹出 的 快捷 菜单 中 选择 Open Apache Monitor 命令 ， 打 开 Apache 监控 程序 ， 其 操作 效果 如 图 2.5 
所 示 。 

(9) 服务 器 开启 后 ,最 后 需要 测试 一 下 服务 器 。 打开 正 浏览 器 页 面 , 在 地 址 栏 中 输入 “http://127. 
0.0.1/” 或 “http://localhost/”， 按 Enter 键 后 系统 会 显示 如 图 2.6 所 示 的 页 面 ， 此 时 说 明 Apache 服务 器 
正式 安装 成 功 。 
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图 2.5 Apache 控制 菜单 图 2.6 Apache 服务 器 运行 页 面 
(10) Apache 服务 器 安装 成 功 后 ， 接 下 来 需要 对 Apache 服务 器 进行 配置 ， 以 便 Apache 服务 器 能 
够 识别 PHP 文件 。 配 置 Apache 服务 器 主要 是 在 Apache 安装 目录 下 的 conf 子 目录 中 的 httpd.conf 文件 
中 进行 的 ， 找 到 该 文件 并 用 记事 本 等 文本 编辑 器 打开 该 文件 。 
(11) 定位 到 LoadModule 配置 块 ， 在 LoadModule 的 最 后 添加 如 下 信息 : 
LoadModule php$_module d:\phpS\phpSApache2 2.dll 


添加 后 的 文件 结果 如 图 2.7 所 示 。 
(12) 修改 DocumentRoot 参数 可 以 修改 Apache 服务 器 主 文档 的 根 目录 。 原 根 目录 的 位 置 是 
Apache2.2\htdocs， 用 户 可 以 任意 指定 位 置 。 如 : 


DocumentRoot "D:/Webpage" 


在 DocumentRoot 的 下 面 间隔 约 28 行 的 位 置 ， 有 一 行为 <Directory "D:/Apache2.2/htdocs">， 修 改 为 
<Directory "D:/Webpage">。 


< 注意 : DocumentRoot 和 这 里 的 参数 值 要 保持 一 致 。 
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(13) 添加 Apache 服务 器 能 够 识别 的 PHP 扩展 名 。PHP 的 扩展 名 有 .php3、.php4、.php、.phtml 
等 。 这 里 只 推荐 使 用 标准 的 扩展 名 .php。 添 加 的 代码 如 下 : 
AddType application/x-httpd-php .php 
添加 位 置 如 图 2.8 所 示 。 
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2.7 加 载 dl 文件 图 2.8 添加 PHP 扩展 识别 


(14) 默认 显示 页 。Apache 的 默认 显示 页 为 index.html。 也 就 是 说 ， 在 服务 器 未 指名 文件 时 ， 首 
先 查找 index.html， 如 果 找 到 index.html， 那 么 服务 器 就 将 加 载 该 文件 ， 否 则 显示 目录 内 的 文件 列表 。 
在 这 里 添加 一 个 PHP 默认 页 : index.php。 更 改 后 的 代码 如 下 : 
DirectoryIndex index.html index.php 
(15) 修改 Apache 端口 号 。Apache 的 端口 号 为 80。 修 改 Listen 选项 的 值 ， 即 可 修改 端口 号 。 如 
改 为 82， 则 更 改 后 的 代码 如 下 : 
Listen 82 


以 上 配置 完成 后 ， 重 启 Apache 服务 器 即 可 。 


4 注意 : 如 果 用 户 的 计算 机 上 还 有 IIS 服务 器 ， 那 么 可 能 会 因为 端口 冲突 而 导致 Apache 无 法 正常 开 
启 。 解 决 的 办 法 是 改变 其 中 的 一 个 端口 号 ， 或 者 停止 IIS 服务 器 。 


2.2.2 在 Linux 下 安装 Apache 服务 器 


鳃 om 视频 讲解 ， 光盘 \TMVVideow\ 在 Linux 下 安装 Apache 服务 器 .exe 


在 Linux 下 安装 Apache 需要 到 官方 网 站 http://www.apache.org 下 载 Linux 下 的 httpd2.2.8.tar.gz 的 
压缩 包 。 


首先 需要 打开 Linux 终端 (Linux 下 几乎 所 有 的 软件 都 需要 在 终端 下 安装 ) 。 在 RedHat 9 的 界面 
中 选择 “ 主 菜单 ”/“ 系 统 工具 ”命令 ， 在 弹出 的 菜单 中 选择 “终端 ”命令 。 
在 Linux 下 安装 和 配置 Apache 服务 器 的 操作 步骤 如 下 : 
(1) 进入 到 Apache 安装 文件 的 目录 下 ， 如 /usr/local/work。 
cd /usr/local/work/ 


(2) 解压 安装 包 。 完 成 后 进入 到 httpd2.2.8 目录 中 。 
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tar xfz httpd2.2.8.tar.gz 
cd httd2.2.8 


(3) 建立 makefile， 将 Apache 服务 器 安装 到 user/local/Apache2 下 。 
/configure -prefix=/usrlocal/Apache2 -enable-module=so 

(4) 编译 文件 。 
make 

(5) 开始 安装 。 
make install 

(6) 安装 完成 后 ， 将 Apache 服务 添加 到 系统 启动 项 中 ， 重 启 服务 器 。 


/usr/local/Apache2/bin/Apachectl] start >> /etc/rc.d/rc.local 
/usr/local/Apache2/bin/Apachectl] restart 


(7) 打开 Mozilla 浏览 器 ， 在 地 址 栏 中 输入 “http://localhost/”， 按 Enter 键 后 如 果 看 到 如 图 2.9 
所 示 的 页 面 ， 说 明 Apache 服务 器 已 安装 成 功 。 
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SO UE Pe 
和 2.9 ”Linux 下 的 Apache 服务 器 安装 页 面 


2.3 PHP 的 安装 和 配置 


2.3.1 在 Windows 下 安装 PHP 


余 视频 讲解 ， 光盘 \TMVVideov2\ 在 Windows 下 安装 PHP.exe 

架设 基于 PHP 的 Web 服务 器 ， 必 须 安装 PHP。 由 于 PHP 的 代码 公开 ， 所 以 其 升级 速度 较 快 。 安 
装 PHP 之 前 应 从 其 官方 网 站 http://www.php net 下 载 最 新 版 本 的 PHP 安装 程序 php-5.2.5-Win32.zip。 

Apache 服务 器 顺利 启动 后 ， 接 下 来 安装 PHP 5。 在 Windows 下 安装 和 配置 PHP 的 操作 步骤 如 下 : 


(1) 将 PHP 5 的 安装 文件 php-5.2.5-Win32.zip 解压 到 相应 目录 ， 如 c:\php、d:\php5 等 。 这 里 将 其 
放 到 d:\php5 目录 下 。 目 录 结 构 如 图 2.10 所 示 。 
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图 2.10 PHP 5 的 目录 结构 


(2) 将 该 目录 下 的 所 有 dll 文件 复制 到 系统 盘 Windows\system32 目录 下 (Windows 2000 是 在 
winnt\system32 目录 下 ) 。 

(3) 将 文件 php.ini-dist 文件 复制 到 系统 盘 \Windows 目录 下 ， 并 重新 命名 为 php.ini。 

(4) 打开 php.ini 文件 并 找到 “extension dir= "./"” 这 一 行 ， 修 改 为 “extension dir = "d:/php5/ext"”。 

(5) 找到 “;extension=php_mysql.dll” 这 一 行 ， 将 前 面 的 分 号 “;” 去 掉 。 这 样 ，PHP 即 可 支持 
MySQL 数据 库 。 

(6) PHP 配置 完成 以 后 ， 重 新 启动 Apache 服务 器 。 

(7) 编写 一 个 PHP 脚本 文件 ， 命 名 为 phpinfo.php， 保 存在 Apache 服务 器 的 虚拟 目录 D:/htdocs 
下 。PHP 脚本 文件 的 代码 如 下 : 


<?php 
phpinfo0: // 获 取 PHP 的 配置 信息 


es 


最 后 在 浏览 器 的 地 址 栏 中 输入 “http://localhost/phpinfo.php”， 如 果 显示 PHP 的 版 本 相关 信息 ， 则 
说 明 PHP 配置 成 功 。 


2.3.2 在 Linux 下 安装 PHP 


使 m 视频 讲解 :光盘 \TM\Video\2\ 在 Linux 下 安装 PHP.exe 
安装 PHP 5 之 前 ， 需 要 首先 查看 libxml 的 版 本 号 。 如 果 libxml 版 本 号 小 于 2.5.10， 则 需要 先 安 装 
libxml 高 版 本 。 安 装 libxml 和 php 5 的 步 又 如 下 (如 果 不 需 要 安装 libxml， 则 直接 跳 到 php 5 的 安装 步 
骤 即 可 ) : 
(1) 将 libxml 和 php 5 复制 到 /usr/local/work/ 目 录 下 ， 并 进入 到 该 目录 。 


myv php-5.2.5.tar.gz libxml2-2.6.26.tar.gz /usr/local/work 
cd /usr/local/work 


(2) 分 别 将 libxml2 和 php 解压 。 


tar xfz libxml?2-2.6.62.tar.gz 
tar xfz PHP-5.2.5.tar.gz 
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(3) 进入 到 libxml 目录 ， 建 立 makfile， 将 libxml 安装 到 /usr/local/libxml2 下 。 


cd libxml2-2.6.62 
-/configure -prefix=/usrlocallibxml2 


(4) 编译 文件 。 
makefile 
(5) 开始 安装 。 
make install 
(6) libxml2 安装 完毕 ， 开 始 安装 php 5。 进 入 到 php-5.2.5 目录 下 。 
cd ./php-5.2.5 
(7) 建立 makefile。 
/configure _with-apxs2=/usr/local/Apache2/bin/apxs 
--with-mysql=/usr/local/mysql 
--with-libxml-dir=/usr/local/libxml2 
(8) 开始 编译 。 
make 
(9) 开始 安装 。 
make install 
(10) 复制 php.ini-dist 或 php.ini-recommended 到 /usrlocallib 目录 ， 并 命名 为 php.ini。 
cp php.ini-dist /usr/local/lib/php.ini 
(11) 更 改 httpd.conf 文件 相关 设置 ， 该 文件 位 于 /usr/local/Apache2/conf 中 。 找 到 该 文件 中 的 如 下 
指令 行 : 
AddType application/x-gzip .gz .tgz 
在 该 指令 后 加 入 如 下 指令 : 
AddType application/x-httpd-php .php 
重新 启动 Apache， 并 在 Apache 主 目录 下 建立 文件 phpinfo.php。 
<?php 


Phpinfo0: 
Ys 


在 Mozilla 浏览 器 的 地 址 栏 中 输入 “http://localhost/phpinfo.php”， 如 果 出 现 如 图 2.11 所 示 的 页 面 ， 
说 明 PHP 安装 成 功 。 
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2.4 MySQL 服务 器 的 安装 和 配置 
2.4.1 在 Windows 下 安装 MySQL 服务 器 


镶 m 视频 讲解 :光盘 \TM\VideoW2\ 在 Windows 下 安装 MySQL 服务 器 .exe 

MySQL 是 一 款 广 受 欢迎 的 数据 库 ， 由 于 开源 所 以 市 场 占有 率 高 ， 备 受 PHP 开发 者 的 青睐 ,一直 
被 认为 是 PHP 的 最 佳 搭 档 。 这 是 因为 MySQL 不 仅 是 完全 网 络 化 的 跨 平台 关系 型 数据 库 系统 ， 也 是 具 
有 客户 机 /服务 器 体系 结构 的 分 布 式 数据 库 管 理 系统 。 它 具有 功能 性 强 、 使 用 简捷 、 管 理 方便 、 运 行 速 
度 快 、 版 本 升级 快 、 安 全 性 高 等 优点 , 而 且 MySQL 数据 库 完 全 免费 , 从 官方 网 站 http://www.mysql.com 
即 可 免费 下 载 到 最 新 版 本 的 MySQL 安装 包 mysql-essential-5.0.51-win32.msi。 


[EO 说明 : 在 学 习 MySQL 数据 库 之 前 ， 读 者 几乎 不 会 接触 到 数据 库 知 识 ， 也 使 用 不 到 MySQL 数据 库 ， 
因此 读者 可 以 暂时 不 用 安装 MySQL 而 专心 学 习 PHP 知识 , 以 免 在 开始 学 习 MySQL 数据 库 
时 由 于 时 间 间 隔 过 长 ， 而 忘记 当初 安装 时 设置 的 用 户 名 和 密码 。 
在 Windows 下 安装 和 配置 MySQL 服务 器 的 操作 步骤 如 下 。 
(1) 双击 MySQL 安装 文件 mysql-essential-5.0.51-win32.msi， 进 入 欢迎 页 面 。 单 击 Next 按钮 ， 进 
入 到 Setup Type 页 面 。 
(2) Setup Type 页 面 中 包含 3 个 安装 选项 ， 第 一 项 是 典型 安装 ， 第 二 项 是 全 部 安装 。 这 两 个 安装 
的 路 径 不 能 改变 ， 默 认 是 E:\Program Files\MySQLAMYSQL Server 5.0\ (E 盘 为 系统 盘 ) 。 第 三 项 是 自 定 
义 安装 ， 人 允许 用 户 自 定义 选择 安装 组 件 和 安装 路 径 。 这 里 选中 Custom 单 选 按钮 。Setup Type 页 面 的 设 
置 如 图 2.12 所 示 。 
(3) 单 击 Next 按钮 进入 到 Custom Setup 页 面 。 选 择 需 要 安装 的 组 件 ， 并 单 击 Change 按钮 来 选择 
要 安装 的 目录 。Custom Setup 页 面 的 设置 如 图 2.13 所 示 。 选 择 完毕 后 单 击 Next 按钮 进入 到 准备 安装 页 面 。 
(4) 在 准备 安装 页 面 中 显示 了 用 户 所 选择 的 安装 类 型 (type) 、 路 径 等 信息 。 如 果 发 现 前 面 的 选项 设 
置 有 误 ， 可 以 单 击 Back 按钮 返回 到 上 一 个 页 面 重新 选择 ， 如 果 正 确 ， 则 单 击 Install 按钮 开始 安装 文件 。 
(5) 文件 安装 完成 后 ,会 出 现 一 些 关 于 MySQL 的 功能 和 版 本 的 介绍 。 连 续 单 击 Next 按钮 ， 将 会 


PHP 开发 实战 宝典 


进入 MySQL 服务 器 配置 页 面 ， 如 图 2.14 所 示 。 
(6) 该 页 面 有 两 个 选项 : 详细 配置 (默认 〉 和 标准 配置 。 这 里 保持 默认 设置 。 单 击 Next 按钮， 
进入 到 服务 器 运行 模式 页 面 ， 如 图 2.15 所 示 。 
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图 2.14 MySQL 服务 器 配置 页 面 2.15 选择 服务 器 运行 模式 


(7) 该 页 面 中 有 3 个 选项 ， 这 里 选择 第 一 个 默认 项 即 可 〈 即 开发 模式 ，MySQL 服务 器 占用 最 小 
的 内 存 空 间 ， 作 为 本 地 测试 使 用 完全 足够 ) 。 选 择 完毕 后 ， 单 击 Next 按钮 进入 选择 数据 库 类 型 页 面 。 

(8) 本 页 面 有 两 种 数据 库 类 型 的 选项 ， 第 一 项 是 支持 MyISAM、InnoDB 等 多 种 类 型 库 的 数据 系 
统 ; 第 二 项 是 只 支持 其 中 一 种 类 型 库 。 这 里 选择 默认 的 第 一 项 : Multifunctional Database， 支 持 多 种 类 
型 库 。 单 击 Next 按钮 ， 如 图 2.16 所 示 。 

(9) 进入 为 InnoDB 数据 文件 选择 路 径 页 面 ， 这 里 选择 D 盘 下 的 MySQL Datafiles 目录 。 选 取 分 
区 时 要 注意 所 选择 分 区 的 剩余 空间 大 小 。 选 择 后 的 页 面 如 图 2.17 所 示 。 单 击 Next 按钮 。 

(10) 进入 选择 同时 连接 服务 器 的 最 大 值 的 页 面 ， 这 里 可 以 选择 默认 的 第 一 项 ， 或 者 选择 第 三 项 
自 定义 连接 。 第 二 项 的 最 大 连接 数 为 500。 选 择 后 的 页 面 如 图 2.18 所 示 。 单 击 Next 按钮 。 

(11) 进入 MySQL 服务 器 的 端口 设置 页 面 ， 默 认 3306 即 可 。 选 取 完 毕 后 单 击 Next 按钮 。 

(12) 进入 选择 MySQL 的 默认 字符 集 页 面 。 这 里 选择 GB2312 编码 类 型 。 单 击 Next 按钮 。 

(13) 进入 选择 MySQL 服务 器 是 否 自动 运行 页 面 。 如 果 要 在 Windows 环境 变量 path 中 加 入 MySQL 
执行 路 径 ， 那 么 需要 选中 Include Bin Directory in Windows PATH 复 选 框 。 页 面 设置 如 图 2.19 所 示 。 单 
击 Next 按钮 ， 进 入 到 权限 设置 页 面 。 
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图 2.19 选择 MySQL 服务 器 的 启动 方式 


(14) 在 该 页 面 中 可 以 设置 用 户 登录 密码 (本 书 中 所 有 涉及 数据 库 的 实例 的 密码 都 为 root， 所 以 
这 里 建议 也 设置 为 root， 以 方便 所 有 MySQL 数据 库 实例 的 运行 )， 在 设置 密码 的 下 面 有 一 行文 本 ， 询 
问 是 否 允许 root 用 户 远程 登录 数据 库 。 如 果 选 中 最 下 面 的 复 选 框 ， 则 创建 一 个 允许 任何 人 访问 数据 库 


的 账号 ， 这 里 不 建议 选中 。 页 面 设置 如 图 2.20 所 示 。 


(15) 单 击 Next 按钮 ， 进 入 准备 执行 页 面 。 如 果 配置 没有 问题 ， 单 击 Execute 按钮 开始 执行 操作 ， 


如 图 2.21 所 示 。 


My5QL Server Instance Configuration 
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图 2.20 权限 设置 页 面 


图 2.21 准备 执行 页 面 


(16) 安装 完成 后 ， 单 击 Finish 按钮 完成 MySQL 服务 器 的 安装 。 
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2.4.2 在 Linux 下 安装 MySQL 服务 器 


铬 ma 视频 讲解 :光盘 \TM\Video\ 在 Linux 下 安装 MySQL 服务 器 .exe 
在 Linux 系统 下 安装 MySQL 服务 器 需要 到 官方 网 站 http://www.mysql.com 下 载 Linux 下 MySQL 
的 安装 包 mysql-5.0.51a-Linux-i686.tar.gz。 
在 Linux 下 安装 和 配置 MySQL 服务 器 的 操作 步骤 如 下 。 
(1) 将 下 载 的 mysql-5.0.51a-Linux-1686.tar.gz 文件 复制 到 /usr/local/work 目录 下 ， 创 建 MySQL 账 
号 ， 并 加 入 组 群 。 


groupadd mysql 
useradd -g mysql mysql 


(2) 进入 到 MySQL 的 安装 目录 ， 将 其 解压 (如 目录 为 /asrlocal/mysql) 。 


cd /usr/local/mysql 
tar xfz /usr/local/work/mysql-5.0.51a-Linux-i686.tar.gz 


(3) 考虑 到 MySQL 数据 库 升 级 的 需要 ， 所 以 通常 以 链接 的 方式 建立 /usr/localmysql 目录 。 
ln -s mysql-5.0.51a-Linux-i686.tar.gz mysql 
(4) 进入 到 MySQL 目录 ， 在 /usr/local/mysql/data 中 建立 MySQL 数据 库 。 


cd mysql 
Scripts/mysql install db -user=mysql 


(5) 修改 文件 权限 。 


chown -R root 
chown -R mysql data 
chgrp -R mysql 


(6) 到 此 MySQL 安装 成 功 。 用 户 可 以 通过 在 终端 中 输入 命令 启动 MySQL 服务 。 
/usrlocal/mysql/bin/mysqld_safe -user=mysql & 
启动 后 输入 命令 ， 进 入 MySQL 。 
/user/local/mysql/bin/mysql -uroot 
如 果 终 端 页 面 显 示 如 图 2.22 所 示 的 提示 信息 ， 则 说 明 MySQL 服务 器 安装 成 功 。 


2.22 测试 MySQL 是 否 安装 成 功 
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2.5 ”初学 者 一 一 应 用 组 合 包 快速 搭建 PHP 环境 


组 合 包 ， 就 是 将 Apache、PHP 和 MySQL 等 服务 器 软件 和 工具 安装 配置 完成 后 打包 处 理 。 开 发 人 
员 只 要 将 已 配置 的 套件 解压 到 本 地 硬盘 中 即 可 使 用 ， 无 须 再 另行 配置 。 组 合 包 实现 了 PHP 开发 环境 的 
快速 搭建 。 对 于 刚刚 起 步 学 习 PHP 的 程序 员 , 建议 采用 此 方法 搭建 PHP 的 运行 环境 。 组 合 包 安装 简单 、 
速度 较 快 、 运 行 稳定 ， 使 用 户 能 将 精力 更 好 地 集中 到 PHP 的 学 习 中 。 
目前 网 上 流行 的 组 合 包 有 十 几 种 ， 安 装 基本 都 是 大 同 小 异 。 这 里 推荐 3 种 组 合 包 : EasyPHP、 
AppServ、XAMPP。 
建议 新 手 使 用 EasyPHP 或 AppServ， 两 者 都 是 Apache+MySQL+PHP 开发 环境 的 。 而 XAMPP 则 
相对 要 复杂 一 些 。 不 仅 可 以 切换 PHP 4 和 PHP 5， 还 集成 了 perl 开发 环境 、 第 三 方 扩展 库 等 ， 并 且 对 
开发 平台 进行 了 优化 和 整理 。 如 果 对 PHP 的 开发 环境 已 经 有 了 一 定 的 了 解 ， 则 推荐 使 用 XAMPP。 
回 EasyPHP 下 载 地 址 为 http://www.easyphp.org/。 
AppServ 下 载 地 址 为 http://www.appservnetwork.com/。 
XAMPP 下 载 地 址 为 http://www.Apachefriends.org/。 
< 注意 : 要 安装 这 些 组 合 包 ， 必 须 保证 系统 中 未 安装 Apache、PHP 和 MySQL。 否则 ， 要 先 将 这 些 软 
件 印 载 后， 再 开始 安装 组 合 包 。 组 合 包 的 安装 很 简单 ， 只 要 将 程序 解压 或 安装 到 指定 目录 后 
就 可 以 直接 使 用 。 
本 节 以 AppServ 组 合 包 的 AppServ-win32-2.5.7 版 本 为 例 ， 重 点 讲解 该 组 合 包 的 安装 和 使 用 方法 。 
AppServ 是 PHP 网 页 架 站 工具 组 合 包 ， 是 将 网 络 上 免费 的 架 站 资源 重新 包装 成 单一 的 安装 程序 。 
它 提供 了 简易 、 快 速 的 PHP 运行 环境 的 搭建 机 制 ， 读 者 只 需 按照 普通 应 用 软件 的 安装 方式 就 可 以 完成 
Apache+MySQL+PHP+phpMyAdmin 的 安装 与 配置 工作 。 可 以 说 ，AppServ 是 初学 者 的 首选 。 
安装 AppServ 之 前 应 从 官方 网 站 http://www.appservnetwork.com 下 载 AppServ-win32-2.5.7.exe 安装 
程序 。 
各 4 视频 讲解 光盘 \TMNVideo\2\ 应 用 组 合 包 快速 搭建 PHP 环境 .exe 
在 Windows 下 应 用 AppServ 组 合 包 快速 搭建 PHP 开发 环境 的 操作 步骤 如 下 。 
(1) 双击 AppServ-win32-2.5.7.exe 文件 ， 打 开 如 图 2.23 所 示 的 AppServ 启动 页 面 。 
(2) 单 击 Next 按钮 ， 打 开 如 图 2.24 所 示 的 AppServ 安装 协议 页 面 。 
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(3) 单 击 IAgree 按钮 将 打开 如 图 2.25 所 示 的 页 面 。 在 该 页 面 中 可 以 设置 AppServ 的 安装 路 径 〈 默 
认 安 装 路 径 一 般 为 C:\AppServ) ，AppServ 安装 完成 后 Apache、MySQL、PHP 都 将 以 子 目录 的 形式 存 
储 到 该 目录 下 。 

(4) 单 击 Next 按钮 将 打开 如 图 2.26 所 示 的 页 面 。 在 该 页 面 中 可 以 选择 要 安装 的 程序 和 组 件 〈 默 
认为 全 选 状态 ) 。 


Select Components 
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居 二 到 


2.25 选择 AppServ 安装 路 径 2.26 AppServ 安装 选项 


(5) 单 击 Next 按钮 ， 打 开 如 图 2.27 所 示 的 页 面 。 该 页 面 主要 用 于 设置 Apache 的 端口 号 。 

(6) 单 击 Next 按钮 ， 打 开 如 图 2.28 所 示 的 页 面 。 该 页 面 主要 用 于 对 MySQL 数据 库 的 root 用 户 
的 登录 密码 及 字符 集 进行 设置 ， 这 里 将 字符 集 设置 为 GB2312 Simplified Chinese， 表 示 MySQL 数据库 
的 字符 集 将 采用 简体 中 文 形式 。 
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图 2.27 设置 Apache 端口 号 图 2.28 设置 MySQL 登录 密码 及 字符 集 


(7) 单 击 Install 按钮 后 开始 安装 ， 如 图 2.29 所 示 。 

(8) 安装 完成 后 可 以 在 开始 菜单 的 AppServ 相关 操作 列表 中 启动 Apache 及 MySQL 服务 ， 如 
图 2.30 所 示 。 

(9) 安装 好 AppServ 之 后 ， 整 个 目录 默认 为 C:\AppServ， 此 目录 下 包含 4 个 子 目 录 ， 如 图 2.31 
所 示 ， 用 户 可 以 将 所 有 网 页 文件 存放 到 www 目录 下 。 
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图 2.29 AppServ 安装 进度 页 面 图 2.30 AppServ 安装 完成 页 面 


Apache 的 存储 目录 

WyS9L 的 存 久 目 录 
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图 2.31 AppServ 目录 结构 


(10) 打开 浏览 器 ， 在 正 浏览 器 的 地 址 栏 中 输入 “http://localhost/” 或 者 “http://127.0.0.1/”， 如 
果 打 开 如 图 2.32 所 示 的 页 面 ， 则 说 明 AppServ 安装 成 功 。 


Change Language :3 ss 


» Easy way to build Webserver, Database Server with AppServ --} 避 
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图 2.32 AppServ 测试 页 


2.6 第 一 个 PHP 程序 


[区 | 视频 讲解 :光盘 \TM\Video\2\ 第 一 个 PHP 程序 .exe 
2.6.1 使 用 Macromedia Dreamweaver 8 编写 源 程序 


服务 器 环境 配置 完成 后 , 接 下 来 应 用 Macromedia Dreamweaver 8 开发 工具 来 编写 第 一 个 PHP 程序。 


29 


PHP 开发 实战 宝典 


例 2.1 编写 第 一 个 PHP 程序 的 目的 是 熟悉 PHP 的 书写 规则 和 Macromedia Dreamweaver 8 工具 的 
基本 使 用 方法 。 本 实例 很 简单 ， 就 像 大 多 数 语言 一 样 ， 输 出 一 段 欢迎 信息 。 开 发 步骤 如 下 : 《实例 位 
置 : 光盘 \TMNInstances\2\1) 

(1) 启动 Macromedia Dreamweaver 8 编辑 器 ， 选 择 “文件 ”/“ 新 建 ” 命 令 ， 打 开 “ 新 建文 档 ” 
对 话 框 ， 在 “常规 ”选项 卡 中 选择 “动态 页 ”类 别 ， 在 “动态 页 ”列表 框 中 选择 PHP 选项 ， 如 图 2.33 
所 示 。 

(2) 单 击 “ 创 建 ” 按 钮 ， 即 可 成 功 创建 一 个 动态 的 PHP 页面。 对 新 创建 的 页 面 ， 可 以 在 “代码 ” 
视图 中 编辑 PHP 代码 ， 也 可 以 使 用 “设计 ”视图 查看 HTML 效果。 这 里 使 用 “代码 ”视图 ， 并 给 该 页 
面 标题 命名 。 如 图 2.34 所 示 ， 标 题 显示 的 位 置 是 在 浏览 器 的 左上 角 ， 稍 后 运行 时 就 能 看 到 效果 。 
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图 2.33 “新 建文 档 ” 对 话 框 图 2.34 命名 标题 
(3) 编写 PHP 代码 。 在 <body>…</body> 标 签 对 中 间 开 始 编写 PHP 代码 段 ， 代 码 如 下 。 
<?php 
echo "欢迎 进入 PHP 的 世界 ! ! ": 
?> 
代码 讲解 : 


回 “<?php” 和 “?>” 是 PHP 的 标记 符 。 在 这 对 标记 符 中 的 所 有 代码 都 被 当 作 PHP 代码 来 处 理 。 
除了 这 种 表示 方法 外 ，PHP 还 可 以 使 用 ASP 风格 的 “<%” 和 SGML 风格 的 “<?…2> ”等 ， 
在 第 3 章 中 将 会 详细 介绍 。 

回 echo 语句 是 PHP 中 最 常用 的 语句 ， 主 要 用 于 将 一 个 或 多 个 字符 串 输 出 至 网 页 ， 和 ASP 中 的 
response.write 以 及 JSP 中 的 out.print 是 一 个 意思 ， 就 是 将 紧 跟 在 后 面 的 字符 串 或 者 变量 值 显 
示 在 页 面 中 。 每 行 代码 都 以 分 号 “;” 结 尾 。 

< 注意 : 在 使 用 echo 语句 时 ， 应 该 时 刻 牢记 语句 结束 处 的 分 号 。 在 PHP 中 ， 分 号 是 用 来 分 隔 语句 的 。 
丢失 这 个 “;” 是 读者 经 常会 犯 的 语法 错误 ， 同 样 也 是 读者 在 进行 程序 的 错误 处 理 时 ， 首 先 
应 该 注 意 的 地 方 。 

在 Macromedia Dreamweaver 8 中 输入 的 PHP 脚本 程序 如 图 2.35 所 示 。 

(4) 将 PHP 动态 页 保存 到 服务 器 指定 的 目录 以 便 解析 。 本 章 中 服务 器 指定 的 目录 为 D:vappserw 


第 2 章 PHP 环境 搭建 


www\， 则 将 本 页 保存 到 D:\appserviwww\tm\s1\2\1\ 路 径 下 ， 命 名 为 index.php。 


on 


2.35 在 开发 工具 中 输入 PHP 脚本 程序 
2.6.2 ”发 布 和 运行 PHP 程序 


打开 下 浏览 器 页 面 ， 在 地 址 栏 中 输入 “http:/127.0.0.1/tm/sl/2/l/index.php” 
看 index.php 页 的 执行 结果 ， 如 图 2.36 所 示 。 


TD iolal 
了 ROW ”| 


| sneer 
DE- | 三 向 顺 顺 四 


图 2.36 PHP 页 面 运行 结果 
2.7 环境 安装 常见 问题 


2.7.1 Apache 安装 常见 问题 


1. 解决 Apache 服务 器 端口 冲突 


， 按 Enter 键 后 即 可 查 


IIS 服务 器 、 迅 雷 的 默认 端口 号 为 80， 同 Apache 服务 器 默认 端口 号 相同 。 两 者 由 于 采用 了 相同 的 


端口 号 80， 因 此 ， 在 运行 网 页 时 就 会 发 生 冲 突 。 


如 果 用 户 安装 了 IS 服务 器 ， 就 需要 修改 TS 的 默认 端口 ， 否 则 将 导致 Apache 服务 器 无 法 正常 工 


作 。 更 改 IS 的 默认 侦 听 端口 80， 可 以 在 IS 的 管理 器 中 进行 设置 ， 也 可 以 停止 IS 的 服务 。 
如 果 用 户 安装 并 开启 了 迅雷 软件 ， 就 需要 关闭 该 软件 ， 否 则 端口 冲突 将 会 导致 运行 PHP 网 页 程序 


时 出 错 。 


用 户 也 可 以 在 安装 Apache 服务 器 时 将 默认 的 端口 号 进行 更 改 , 从 而 解决 两 个 服务 器 或 与 其 他 软件 


共用 一 个 端口 号 而 产生 冲突 的 问题 。 
2. 更 改 Apache 服务 器 默认 存储 的 文件 路 径 


Apache 服务 器 的 核心 配置 文件 是 httpd.conf， 存 放 路 径 为 “Apache 的 安装 路 径 \conf”， 用 记事 本 
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print"<table width="750' border='l' cellpadding='1' cellspacine="1' bordercolor=#FFFFFF' bgcolor=#99CC00> 
<tr><td width="131' align='center' bgcolor=#FFFFFF'><span class='STYLE 5 人 > 标题 </span></td><td width='258' align= 
'center bgcolor=#FFFFFF'><span class-'STYLE 5> 链 接地 址 </span></td><td width='343' align='center bgcolor= 
FFFFFF'><span class='STYLE 5> 内 容 摘 要 </span></td></ar>": 
for($i=0:$i<$node record->length:SitH{ // 根 据 标签 的 数量 执行 for 循环 
$k=0; 
foreach(Snode record->item($i)->childNodes as $articles){ // 通 过 foreach 语句 输出 标签 中 的 数据 
Sfield[$k]=iconv("UTF-8","GB2312",$articles->textContent); 
Sk++; 
} 
Print"<tr><td align='left bgcolor=#FFFFFF>"; 
print"$field[O]":; 
Print"</td><td align='left’ bgcolor='#FFFFFF'>": 
print"Sfield[1]": 
Print"</td><td align='left’ bgcolor='#FFFFFF'>"; 
print"$field[21"; 


Print"</td></tr>"; 
} 
Print"</table>"; 

} 

} 

?> 


(2) 实例 化 Message_ XML 类 ， 并 通过 实例 化 的 对 象 ShawkXML 调用 show_message0 方 法 ， 输 出 
存储 在 XML 文件 中 的 内 容 ， 关 键 代 码 如 下 。 


<2php 
ShawkXML=new Message XML: 
$Action=$_GET['Action']; 
switch($Action){ 
case "show_message": 
ShawkXML->show_message(); 
break: 


?> 
运行 结果 如 图 22.10 所 示 。 
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PHP 中 的 DOM 函数 库 十 分 庞大 , 这 里 只 是 对 创建 和 读 取 XML 文档 所 使 用 的 方法 进行 了 介绍 。 感 
兴趣 的 读者 可 以 参考 XML 和 PHP 的 官方 手册 来 了 解 更 多 关于 DOM 的 知识 。 


22.5.3 ”通过 XPath 查询 XML 中 的 数据 


| 视频 讲解 : 光盘 \TM\Video\22\ 通 过 XPath 查询 XML 中 的 数据 .exe 

通过 DOM 类 库 查询 XML 数据 主要 应 用 的 是 XPath， 通 过 DOMXPath->query0 方 法 来 执行 查询 特 
定 的 节点 。DOMXPath->query() 方 法 在 XML 中 执行 查询 的 操作 ， 查 询 符合 一 些 模 式 语法 的 特定 节点 。 
返回 值 为 一 个 节点 列表 对 象 。 语 法 如 下 : 


class DOMXPath { 
DOMNodeList query ( string expression [, DOMNode contextnode] ) 


} 

参数 expression 是 执行 的 查询 语句 ， 该 参数 的 输出 写法 有 多 种 ， 进 而 可 分 割 执行 不 同 的 查询 操作 。 
例如 : 

/rss/channel/item[position() = 1]/tile ” 返回 第 一 个 item 元 素 的 所 有 title 

/rss/channel/item/title[@id ="23"] 返回 所 有 含有 id 属性 且 值 为 23 的 title 

/rss/channel/&folderé&:/title 返回 所 有 articles 元 素 下 面 的 tile(&folder& 代 表 目 录 深 度 ) 

其 返回 值 为 ， 如 果 成 功 则 返回 一 个 节点 列表 对 象 DOMNodeList， 如 果 失 败 则 返回 一 个 空 的 节点 列 
表 对 象 DOMNodeList。 

例 22.14 ”应 用 DOMXPath->query0 方 法 ， 实 现 对 XML 文档 中 的 数据 进行 查询 操作 ， 查 询 XML 文 
档 中 标题 是 “明日 科技 ”的 数据 ， 将 查询 结果 输出 到 文本 框 中 ， 操 作 步 又 如 下 : 〔 实 例 位 置 ， 光 
盘 \TMNInstances\22\14) 

(1) 编写 一 个 Message XML 类 , 该 类 继承 于 DomDocument 类 , 应 用 该 类 的 load0 方 法 调用 XML 

文件 Rss.xml， 在 Message XML 类 中 建立 select_message() 方 法 ， 通 过 该 函数 实现 查询 XML 文件 中 数 
据 的 操作 ， 代 码 如 下 。 


<?php 
class Message XML extends DomDocument{ // 定 义 类 
Private SRoot: 
public function constructO { /构造 函数 
Parent:: constructO: 
S$this->load("Rss.xml"):} // 加 载 指定 的 文件 
public fnction select_message($Action){ // 创 建 方法 
$Root = S$this->documentElement; 
Sxpath = new DOMXPath($this): // 定 义 DOMXPath 
$node Record = $xpath->query("//item[title='$Action']"): // 执 行 查询 语句 
for($i=0:$i<$node_Record->length:$i++){ // 应 用 for 循环 输出 查询 结果 
$e=0; 
foreach($node_Record->item($i)->childNodes as $node){// 通 过 foreach 语句 读 取 返 回 对 象 中 的 数据 
Sfield[$g]=iconv("UTF-8"."GB2312".Snode->textContent): // 实 现 编 码 格式 的 转换 
$g++: 
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} 
// 输 出 查询 结果 
/省 略 了 输出 查询 结果 的 代码 
1 
} 


时 


(2) 创建 一 个 操作 界面 ， 插 入 一 个 表单 、 文 本 框 ， 设 置 提 交 按 钮 ， 然 后 对 Message XML 类 进行 
实例 化 ， 并 应 用 实例 化 后 的 对 象 ShawkXML 调用 select_message0 方 法 执行 查询 操作 ， 关 键 代码 如 下 。 


<?php 
if($Submit==true){ 
ShawkXML = new Message XML: 
ShawkXML->select_message(iconv("GB2312","UTF-8","$ POST[Action]")): 
} 
?> 


.的 技巧 : 在 执行 查询 操作 过 程 中， 必须 要 对 提交 的 字符 囊 进行 编码 格式 的 转换 ， 因 为 在 XML 文件 中 
使 用 的 是 UTF-8 的 编码 格式 ， 而 程序 中 提交 的 数据 使 用 的 是 GB2312 编码 ， 所 以 要 将 提交 
的 数据 转换 成 UTF-8 的 编码 格式 ， 否 则 是 不 能 进行 匹配 查询 的 。 对 编码 格式 的 转换 使 用 的 
是 iconv0O 函 数 。 


运行 本 实例 ， 在 文本 框 中 输入 关键 字 “ 明 日 科技 ”， 将 输入 如 图 22.11 所 示 的 内 容 。 
vs 人 tt net orer =iOlx) 


图 22.11 通过 XPath 查询 XML 中 的 数据 


22.6 本 章 小 结 


本 章 首先 介绍 了 XML 的 基础 语法 , 使 读者 对 XML 有 了 一 个 初步 的 印象 ; 然后 讲解 了 如 何在 PHP 
中 创建 一 个 XML 文档; 接着 对 PHP 5 最 新 的 SimpleXML 类 库 进行 了 详细 的 介绍 ， 最 后 使 用 DOM 对 
象 模型 动态 创建 了 一 个 XML 文档 。 

希望 读者 可 以 通过 本 章 的 概念 和 实例 ， 初 步 掌 握 PHP 对 XML 文档 的 操作 ， 为 学 习 后 面 的 Ajax 技 
术 做 好 准备 。 
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22.7 实战 练习 


1. 通过 DOM 类 库 向 XML 中 添加 数据 。 (答案 位 置 ; 光盘 \TM\Instances\22\15) 
2. 通过 replaceChild0 方 法 修改 XML 文档 。 (答案 位 置 ， 光盘 \TMNInstances\22\16) 
3. 通过 removeChild0 方 法 删除 XML 文档 。 (答案 位 置 : 光盘 \TMNInstances\22\17) 
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23.1 Ajax 概述 


随 着 Web 2.0 时 代 的 到 来 ，Ajax 技术 产生 并 逐渐 成 为 主流 的 Web 应 用 。 相 对 于 传统 的 Web 应 用 
发 ，Ajax 运用 的 是 更 加 先进 、 更 加 标准 化 、 更 加 高 效 的 Web 开发 技术 体系 。 由 于 Ajax 是 客户 端 技 
术 ， 其 编译 和 执行 由 浏览 器 完成 ， 所 以 无 论 哪 种 Web 语言 都 可 以 使 用 Ajax 技术 开发 前 台 应 用 和 页 面 
特效 。 本 章 主 要 介绍 Ajax 技术 及 如 何在 PHP 中 应 用 Ajax 技术 。 


23.1.1 什么 是 Ajax 


Ajax 是 JavaScript、XML、CSS、DOM 等 多 种 已 有 技术 的 组 合 ， 可 以 实现 客户 端的 异步 请 求 操作 ， 
这 样 可 以 实现 在 不 需要 刷新 页 面 的 情况 下 与 服务 器 进行 通信 ， 从 而 减少 了 用 户 的 等 待 时 间 。Ajax 是 由 
Jesse James Garrett 创造 的 ， 是 Asynchronous JavaScript And XML 的 缩写 ， 即 异步 JavaScript 和 XML 技 
术 。 可 以 说 ，Ajax 是 “增强 的 JavaScript”， 是 一 种 可 以 调用 后 台 服 务 器 获得 数据 的 客户 端 JavaScript 
技术 ， 支 持 更 新 部 分 页 面 的 内 容 而 不 重 载 整个 页 面 。 


23.1.2 Ajax 的 开发 模式 
传统 的 Web 应 用 模式 中 ， 页 面 中 用 户 的 每 一 次 操作 都 将 触发 一 次 返回 Web 服务 器 的 HTTP 请 求 ， 
服务 器 进行 相应 的 处 理 后 ， 返 回 一 个 HTML 页 面 给 客户 端 浏览 器 。Ajax 中 ， 页 面 中 用 户 的 操作 将 通过 


Ajax 引擎 与 服务 器 端 进行 通信 ， 然 后 将 返回 结果 提交 给 客户 端 页 面 的 Ajax 引擎 ， 再 由 Ajax 引擎 来 决 
定 将 这 些 数据 插入 到 页 面 的 指定 位 置 。 一 个 典型 的 Ajax 应 用 如 图 23.1 所 示 。 


二 


二 
由 上 
Ea 


| < 一 -一 一 


Pe 


图 23.1 典型 的 Ajax 应 用 
23.1.3 Ajax 的 优点 
Ajax 在 用 户 与 服务 器 之 间 引 入 了 Ajax 引擎 作为 中 间 媒 介 , Web 页 面 不 用 打 断 交互 流程 就 可 以 重新 
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加 载 ， 实 现 动态 更 新 ， 从 而 可 以 消除 网 络 交互 过 程 中 “处 理 一 等 待 一 处 理 一 等 待 ”的 缺点 。 也 就 是 说 ， 
不 需 刷新 客户 端 浏 览 器 就 可 以 实现 重新 向 服务 器 发 出 请 求 。 
使 用 Ajax 的 优点 具体 表现 在 以 下 几 个 方面 : 
回 “无 刷新 更 新 页 面 。Ajax 使 用 XMLHttpRequest 对 象 向 服务 器 发 送 请 求 并 得 到 服务 器 响应 ， 在 
不 需要 重新 载 入 整个 页 面 的 情况 下 ， 即 可 根据 服务 器 端 返 回 的 请 求 更 改 页 面 内 容 ， 使 用 Ajax 
技术 可 以 有 效 减少 用 户 等 待 页 面 刷新 的 时 间 。 
回 ”可 以 把 一 部 分 以 前 由 服务 器 负担 的 工作 转移 到 客户 端 ， 利 用 客户 端 闲 置 的 资源 进行 处 理 ， 减 
轻 服务 器 和 带宽 的 负担 ， 节 约 空间 和 宽带 租用 成 本 。 
回 ”减轻 服务 器 的 负担 。Ajax 的 原则 是 “ 按 需 求 获取 数 据 ”， 可 以 最 大 程度 地 减少 元 余 请 求 和 响 
应 对 服务 器 造成 的 负担 。 
回 ”可 以 调用 XML 等 外 部 数据 ， 进 一 步 促 进 Web 页 面 显示 和 数据 的 分 离 。 
回 Ajax 是 基于 标准 化 并 被 广泛 支持 的 技术 ， 不 需要 下 载 插件 或 者 小 程序 。 


23.2 ”Ajax 技术 的 组 成 


Ajax 技术 并 不 是 一 种 新 型 的 语言 ， 而 是 多 种 已 有 的 Web 技术 的 整合 ， 主 要 包括 JavaScript、XML 
语言 、DOM 和 CSS 等 。 


23.2.1 JavaScript 脚本 语言 


JavaScript 是 一 种 解释 型 的 、 基 于 对 象 的 脚本 语言 ， 其 核心 已 经 嵌入 到 目前 主流 的 Web 浏览 器 中 。 
虽然 平时 应 用 最 多 的 是 通过 JavaScript 实现 一 些 网 页 特效 及 表单 数据 验证 等 功能 ， 但 JavaScript 可 以 实 
现 的 功能 远 不 止 这 些 。JavaScript 是 一 种 具有 丰富 的 面向 对 象 特性 的 程序 设计 语言 ， 利 用 它 能 执行 许多 
复杂 的 任务 ， 例 如 ，Ajax 就 是 利用 JavaScript 将 DOM、XHTML (或 HIML) 、XML 以 及 CSS 等 技 
术 综 合 起 来 ， 并 控制 它们 的 行为 。 因 此 ， 要 开发 一 个 复杂 高 效 的 Ajax 应 用 程序 ， 就 必须 对 JavaScript 
有 深入 的 了 解 。 

JavaScript 不 是 Java 语言 的 精简 版 , 并 且 只 能 在 某 个 解释 器 或 “宿主 ”上 运行 , 如 ASP、PHP、JSP、 
Internet 浏览 器 或 者 Windows 脚本 宿主 。 

JavaScript 是 一 种 宽松 类 型 的 语言 ， 宽 松 类 型 意味 着 不 必 显 式 定义 变量 的 数据 类 型 。 此 外 ， 在 大 多 
数 情况 下 ，JavaScript 将 根据 需要 自动 进行 转换 。 例 如 ， 如 果 将 一 个 数值 添加 到 由 文本 组 成 的 某 项 〈 一 
个 字符 串 ) ， 该 数值 将 被 转换 为 文本 。 


23.2.2 XMLHttpRequest 对 象 


镶 m 视频 讲解 : 光盘 \TMVideo\23\VXMLHttpRequest 对 象 .exe 
XMLHttpRequest 是 Ajax 中 最 核心 的 技术 , 它 是 一 个 具有 应 用 程序 接口 的 JavaScript 对 象 ， 能 够 使 
用 超 文本 传输 协议 (HTTP) 连接 一 个 服务 器 ， 是 微软 公司 为 了 满足 开发 者 的 需要 ， 于 1999 年 在 IE 5.0 
浏览 器 中 率先 推出 的 。 现 在 许多 浏览 器 都 对 其 提供 了 支持 ， 不 过 实现 方式 与 正 有 所 不 同 。 使 用 
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XMLHttpRequest 对 象 , Ajax 可 以 像 桌面 应 用 程序 一 样 只 同 服务 器 进行 数据 层面 的 交换 ， 而 不 用 每 次 都 
刷新 页 面 ， 也 不 用 每 次 都 将 数据 处 理 的 工作 交 给 服务 器 来 做 ， 这 样 既 减 轻 了 服务 器 负担 又 加 快 了 响应 
速度 ， 缩 得 了 用 户 等 待 的 时 间 。 


使 用 XMLHttpRequest 对 象 发 送 请 求 和 处 理 响 应 之 前 ， 首 先 需 要 初始 化 该 对 象 ， 由 于 XMLHttpRequest 


不 是 一 个 W3C 标准 ， 所 以 对 于 不 同 的 浏览 器 ， 初 始 化 的 方法 也 是 不 同 的 。 


司 
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回 正 浏 览 器 

正 浏览 器 把 XMLHttpRequest 实例 化 为 一 个 ActiveX 对 象 。 具 体 方法 如 下 : 

Var http request = new ActiveXObject("Msxml2.XMLHTTP"); 

或 者 

var http request = new ActiveXObject("Microsoft.XMLHTTP"); 

上 面 语法 中 的 Msxml2.XMLHTTP 和 Microsoft.XMLHTTP 是 针对 正 浏览 器 的 不 同 版 本 而 进行 设置 
目前 比较 常用 的 是 这 两 种 。 

加 ”Mozilla、Safari 等 其 他 浏览 器 

Mozilla、Safari 等 其 他 浏览 器 把 它 实例 化 为 一 个 本 地 JavaScript 对 象 。 具 体 方法 如 下 : 


var http_request = new XMLHttpRequestO; 


为 了 提高 程序 的 兼容 性 ， 可 以 创建 一 个 跨 浏览 器 的 XMLHttpRequest 对 象 。 方法 很 简单 ， 只 需要 判 


-下 不 同 浏览 器 的 实现 方式 ， 如 果 浏览 器 提供 了 XMLHttpRequest 类 ， 则 直接 创建 一 个 实例 ， 否 则 使 


用 正 的 ActiveX 控件 。 具 体 代码 如 下 : 


if (window.XMLHttpRequest) { //Mozilla、Safari 等 浏览 器 
http_request = new XMLHttpRequest(); 
} 
else if (window.ActiveXObject) { // 正 浏览 器 
uy{ 
http_request = new ActiveXObject("Msxml2.XMLHTTP"): 
} catch (e) { 
yt{ 
http_request = new ActiveXObject("Microsoft. XMLHTTP"): 
} catch (e) 他 
} 
} 


由 于 JavaScript 具有 动态 类 型 特性 ， 而 且 XMLHttpRequest 对 象 在 不 同 浏览 器 上 的 实例 是 兼容 的 ， 


所 以 可 以 用 同样 的 方式 访问 XMLHttpRequest 实例 的 属性 和 方法 , 不 需要 考虑 创建 该 实例 的 方法 。 下 面 
介绍 XMLHttpRequest 对 象 的 常用 方法 和 属性 。 


1. XMLHttpRequest 对 象 的 常用 方法 
(1) open() 方 法 
open() 方 法 用 于 设置 进行 异步 请 求 目 标的 URL、 请 求 方法 以 及 其 他 参数 信息 ， 具 体 语法 如 下 : 
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open("method","URL'"[,asyncFlag[,"userName'"'[, "password"]]]) 
在 上 面 的 语法 中 ，method 用 于 指定 请 求 的 类 型 ， 一 般 为 get 或 post; URL 用 于 指定 请 求 地 址 ， 可 
以 使 用 绝对 地 址 或 者 相对 地 址 , 并 且 可 以 传递 查询 字符 串 ; asyncFlag 为 可 选 参数 , 用 于 指定 请 求 方式 ， 
同步 请 求 为 rue， 异 步 请 求 为 false， 默 认为 true; userName 为 可 选 参 数 ， 用 于 指定 用 户 名 ， 没 有 时 可 
省 略 ，password 为 可 选 参数 ， 用 于 指定 请 求 密码 ， 没 有 时 可 省 略 。 
(2) send() 方 法 
send() 方 法 用 于 向 服务 器 发 送 请 求 。 如 果 请 求 声明 为 异步 ， 该 方法 将 立即 返回 ， 否 则 将 等 到 接收 到 
响应 为 止 。 具 体 语 法 格式 如 下 : 
send(content) 
在 上 面 的 语法 中 ，content 用 于 指定 发 送 的 数据 ， 可 以 是 DOM 对 象 的 实例 、 输 入 流 或 字符 串 ， 如 
果 没 有 参数 需要 传递 可 以 设置 为 null。 
(3) setRequestHeader() 方 法 
setRequestHeader() 方 法 为 请 求 的 HTTP 头 设置 值 。 具 体 语法 格式 如 下 : 
setRequestHeader("label", "value") 
在 上 面 的 语法 中 ，label 用 于 指定 HTTP 头 ，value 用 于 为 指定 的 HTTP 头 设置 值 。 
< 人 注意 : setRequestHeader() 方 法 必须 在 调用 open() 方 法 之 后 才能 调用 。 


(4) abort() 方 法 
abort() 方 法 用 于 停止 当前 异步 请 求 。 
(5) getAllIResponseHeaders() 方 法 
getAllIResponseHeaders() 方 法 用 于 以 字符 串 形式 返回 完整 的 HTTP 头 信息 ， 当 存在 参数 时 ， 表 示 以 
字符 串 形式 返回 由 该 参数 指定 的 HTTP 头 信息 。 
2. XMLHttpRequest 对 象 的 常用 属性 
XMLHttpRequest 对 象 的 常用 属性 如 表 23.1 所 示 。 


表 23.1 XMLHttpRequest 对 象 的 常用 属性 


属 性 说 明 

onreadystatechange 每 次 状态 改变 都 会 触发 这 个 事件 处 理 器 ， 通 常会 调用 一 个 JavaScript 函数 
请 求 的 状态 。 有 以 下 5 个 取 值 : 
0= 未 初始 化 

TeadyState 上 
2= 已 加 载 
3= 交 互 中 
4= 完 成 

responseText 服务 器 的 响应 ， 表 示 为 字符 串 
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续 表 
属 性 说 明 
responseXML 服务 器 的 响应 ， 表 示 为 XML。 这 个 对 象 可 以 解析 为 一 个 DOM 对 象 


返回 服务 器 的 HTTP 状态 码 ， 如 : 
200=" 成 功 " 

202=" 请 求 被 接受 ， 但 尚未 成 功 " 
400=" 错 误 的 请 求 " 
404=" 文 件 未 找到 " 

500= "内 部 服务 器 错误 " 


status 


statusText 返回 HTTP 状态 码 对 应 的 文本 


3. XMLHttpRequest 对 象 与 服务 器 交互 


XMLHttpRequest 对 象 最 大 的 用 途 就 是 不 需要 刷新 页 面 就 可 以 与 服务 器 进行 交互 。 可 以 将 Ajax 与 


服务 器 的 交互 分 为 以 下 3 个 步骤 ， 
(1) 初始 化 XMLHttpRequest 对 象 ， 关 键 代码 如 下 。 
var xmlHttp = false; // 定 义 XMLHttpRequest 对 象 
ty{ 


// 如 果 浏 览 器 支持 XMLHttpRequest 对 象 ， 创 建 ActiveXObject 对 象 
xmlHttp = new ActiveXObject("Msxml2.XMLHTTP"): 
} catch (e) { 
uy{ 
xmlHttp = new ActiveXObject("Microsoft. XMLHTTP"); 
} catch (e2) {} 


} 
if (!xmlHttp && typeof XMLHttpRequest != "undefined") { 
ty{ 
xmlHttp = new XMLHttpRequestO: 
}catch(e3){ xmlHttp = false;} 


(2) 设置 请 求 状态 和 返回 处 理 函 数 ， 语 法 格式 如 下 。 


Xmlobj.onreadystatechange=function name: 


其 中 ，xmlobj 是 XMLHttpRequest 的 对 象 ， function name 是 用 来 处 理 请 求 状态 和 返回 码 的 函数 名 


( 即 回调 函数 ) 。 
(3) 发 送 HTTP 请 求 ， 语 法 格式 如 下 。 


xmlobj.open(send_method.url.flag): 


其 中 ，xmlobj 是 XMLHttpRequest 的 对 象 ; send_method 是 发 送 方法 ， 可 以 是 GET 或 者 POST， 对 


应 表单 使 用 的 方法 ， url 是 页 面 要 调用 的 地 址 ，flag 是 一 个 标记 ， 如 果 为 true 则 表示 在 等 待 被 调用 页 
响应 的 时 间 内 可 以 继续 执行 页 面 代码 ， 反 之 为 false。 
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例 23.1 通过 XMLHttpRequest 对 象 读 取 HTML 文件 ， 并 输出 读 取 结 果 。 关 键 代码 如 下 : 〔 实 例 
位 置 光盘 \TM\Instances\23\1) 


<script langurage="javascript"> 
var xmlHttp; // 定 义 XMLHttpRequest 对 象 
function createXmlHttpRequestObjectO{ 
这 window.ActiveXObjecb{ 
ty{ 
xmlHttp=new ActiveXObject("Microsoft. XMLHTTP"): 
}catch(e){ 
xmlHttp=false: 
} 
jelse{ // 如 果 在 Mozilla 或 其 他 的 浏览 器 下 运行 
by{ 
xmlHttp=new XMLHttpRequestO: 
}catch(e){ 
XmlHttp=false: 
} 


} 
if(!xmlHttp) 
alert(" 返 回 创建 的 对 象 或 显示 错误 信息 "); 
else 
return xmlHttp; 
function ReqHtmlO{ 
createXmlHttpRequestObjectO: 
xmlHttp.onreadystatechange=StatHandler: // 判 断 URL 调用 的 状态 值 并 处 理 
xmlHttp.open("GET","text.html",true); // 调 用 text.html 
xmlHttp.send(nul]); 
} 
function StatHandlerO{ 
if(xmlHttp.readyState—4 &é& xmlHttp.status 一 200){ 
document.getElementById("webpage").innerHTML=xmlHttp.responseText: 
} 
} 
</script> 
<!-- 创 建 超 链接 --> 
<a hre 仁 "#" onclick="ReqHtml0:"> 通 过 XMLHttpRequest 对 象 请 求 HTML 文件 </a> 
<!-- 通 过 div 标签 输出 请 求 内 容 --> 
<div id="webpage"></div> 


本 实例 通过 DIV 标签 输出 请 求 的 HTML 页 面 .在 JavaScript 脚 本 中 ,应 用 document.getElementByIdO 
方法 来 获得 页 面 元 素 。 运 行 本 实例 ， 单 击 “ 通 过 XMLHttpRequest 对 象 请 求 HTML 文件 ” 超 链接 ， 将 
输出 如 图 23.2 所 示 的 页 面 。 

通过 XMLHttpRequest 对 象 不 但 可 以 读 取 HTML 文件 ， 还 可 以 读 取 文本 文件 、XML 文件 ， 其 实现 
交互 的 方法 与 读 取 HTML 文件 类 似 ， 这 里 不 再 举例 。 
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图 23.2 通过 XMLHttpRequest 对 象 读 取 HTML 文件 
23.2.3 XML 语言 


XML 是 eXtensible Markup Language 可 扩展 的 标记 语言 ) 的 缩写 , 它 提 供 了 用 于 描述 结构 化 数据 
的 格式 。XMLHttpRequest 对 象 与 服务 器 交换 的 数据 ， 通 常 采用 XML 格式 ， 但 也 可 以 是 基于 文本 的 其 
他 格式 。 


23.2.4 DOM 


DOM 是 Document Object Model (文档 对 象 模型 ) 的 缩写 , 它 为 XML 文档 的 解析 定义 了 一 组 接口 。 
解析 器 读 入 整个 文档 ， 然 后 构建 一 个 驻 留 内 存 的 树 结构 ， 最 后 通过 DOM 可 以 遍历 树 以 获取 来 自 不 同 
位 置 的 数据 ， 可 以 添加 、 修 改 、 删 除 、 查 询 和 重新 排列 树 及 其 分 支 。 另 外 ， 还 可 以 根据 不 同类 型 的 数 
据 源 来 创建 XML 文档。 在 Ajax 应 用 中 ， 通 过 JavaScript 操作 DOM， 可 以 达到 在 不 刷新 页 面 的 情况 下 
实时 修改 用 户 界面 的 目的 。 


23.2.5 CSS 


CSS 是 Cascading Style Sheet( 层 营 样 式 表 ) 的 缩写， 是 用 于 控制 网 页 样式 并 允许 将 样式 信息 与 网 
页 内 容 分 离 的 一 种 标记 性 语言 。 在 Ajax 中 , 通常 使 用 CSS 进行 页 面 布局 ,并 通过 改变 文档 对 象 的 CSS 
属性 控制 页 面 的 外 观 和 行为 。CSS 是 一 种 Ajax 开发 人 员 所 需要 的 重要 武器 ， 提 供 了 从 内 容 中 分 离 应 用 
样式 和 设计 的 机 制 。 虽然 CSS 在 Ajax 应 用 中 扮演 至 关 重 要 的 角色 , 但 它 也 是 构建 创建 跨 浏览 器 应 用 的 
一 大 阻碍 ， 因 为 不 同 的 浏览 器 厂商 支持 不 同 的 CSS 级 别 。 


23.3 Ajax 与 PHP 的 交互 


在 23.2 节 介 绍 XMLHttpRequest 对 象 时 ， 讲 解 了 如 何 实现 Ajax 与 HTML 的 交互 。 这 里 将 介绍 
XMLHttpRequest 对 象 与 PHP 的 交互 。 通 过 XMLHttpRequest 对 象 请 求 PHP 页 面 有 两 种 方式 ， 一 种 是 
GET 方式 ， 另 一 种 是 POST 方式 。 具 体 使 用 哪 一 种 方式 与 PHP 进行 交互 ， 取 决 于 PHP 页 面 中 变量 值 
的 传递 方法 ， 如 果 使 用 POST 方法 进行 传递 变量 值 ， 则 使 用 POST 方式 进行 交互 操作 ， 否 则 使 用 GET 
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方式 进行 交互 操作 。 
23.3.1 通过 GET 方式 与 PHP 进行 交互 


镶 a 视频 讲解 :光盘 \TMVideo\23\ 通 过 GET 方式 与 PHP 进行 交互 .exe 
通过 一 个 具体 的 实例 来 讲解 如 何 通过 GET 方式 与 PHP 进行 交互 。 
例 23.2 应 用 GET 方式 ， 通 过 XMLHttpRequest 对 象 与 PHP 进行 交互 ， 其 操作 步骤 如 下 : (实例 
位 置 ， 光盘 \TM\Instances\23\2) 
(1) 创建 index.php 文件 ， 编 写 JavaScript 脚本 ， 通 过 Ajax 请 求 searchrst.php 文件 ， 执 行 查 询 操 
作 ， 将 查询 结果 定义 到 DIV 标签 中 ; 创建 form 表单 ， 提 交 查 询 的 关键 字 ， 通 过 DIV 标签 输出 查询 结 
果 ， 代 码 如 下 。 


<script> 
Var xmlHttp: /定义 XMLHttpRequest 对 象 
function createXmlHttpRequestObijectO{ 
这 window.ActiveXObjecb{ // 如 果 在 Internet Explorer 下 运行 
ty{ 
xmlHttp=new ActiveXObject("Microsoft. XMLHTTP"): 
}catch(e){ 
XmlHttp=false: 
} 
}else{ // 如 果 在 Mozilla 或 其 他 的 浏览 器 下 运行 
ty{ 
xmlHttp=new XMLHttpRequest(): 
}catch(e){ 
xmlHttp=false; 
} 
} 
这 !xmlHttp) /返回 创建 的 对 象 或 显示 错误 信息 
alert(" 返 回 创建 的 对 象 或 显示 错误 信息 "); 
else 
return xmlHttp; 
} 
function showsimpleO{ 
createXmlHttpRequestObjectO: 
var cont = document.getElementById("searchtxt").value: 
if(cont—""){ 
alert( 查 询 关 键 字 不 能 为 空 ! ): 
Tetum false: 
} 
xmlHttp.onreadystatechange=StatHandler: /判断 URL 调用 的 状态 值 并 处 理 
xmlHttp.open("GET".'searchrst.php?cont="+cont.false): 
xmlHttp.send(nulD): 
》 
function StatHandlerO{ 
这 xmlHttp .readyState 一 4 && xmlHttp.status 一 200){ 
document.getElementById("webpage").innerHIML=xmlHttp responseText': 
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$sqles="select * from tb_administrator ": 
S$results=mysql query($sqles.$conn): 
echo "<table width='500' border='l' cellpadding- 1 cellspacing='1l' bordercolor=#FFFFCC' bgcolor= 
#666666>"; 
echo "<tr><td height="30' align='center bgcolor=#FFFFFF'>ID</td><td align='center' bgcolor=#FFFFFF'> 名 
称 </td><td align='center bgcolor=#FFFFFF> 编 号 </td><td align='center bgcolor=#FFFFFF 人 > 描述 </td></tr>"; 
while($myrow=mysql fetch array(Sresults)){ 1/ 循环 输出 查询 结果 
echo "<tr><td height='22' bgcolor=#FFFFFF'>".$myrow[id]."</td>"; 
echo "<td bgcolor=#FFFFFF>".$myrow[user]."</td>"; 
echo "<td bgcolor='#FFFFFF>".$myrow[number]."</td>"; 
echo "<td bgcolor=#FFFFFF'>".$myrow[explains]."</td>"; 
echo “</tr>"; 
} 
echo "</table>"; 
} 


人 
运行 本 实例 ， 无 刷新 添加 员工 信息 后 ， 将 在 当前 页 中 输出 数据 表 中 的 所 有 员工 信息 ， 运 和 
图 23.4 所 示 。 
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23.4 通过 POST 方式 与 PHP 进行 交互 


< 注意 : 本 实例 中 ， 在 获取 Ajax 中 POST 提交 的 数据 时 ， 需 要 对 数据 的 编码 格式 进行 转换 ， 才 能 
将 中 文字 符 串 添加 到 数据 表 中 。 因 为 Ajax 中 的 数据 使 用 的 是 UTF-8 格式 的 编码 ， 如 果 要 将 
该 数据 添加 到 编码 格式 为 GB2312 的 数据 表 中 ， 就 需要 使 用 iconv0 函 数 将 UTF-8 编码 转换 
为 GB2312 编码 。 


23.4 Ajax 开发 常见 问题 


余 视频 讲解 ， 光盘 \TM\Video\23W\Ajax 开发 需要 注意 的 几 个 问题 .exe 

Ajax 在 开发 过 程 中 需要 注意 以 下 几 个 问题 : 

1. 浏览 器 兼容 性 问题 

Ajax 使 用 了 大 量 的 JavaScript 和 Ajax 引擎 ， 而 这 些 内 容 需 要 浏览 器 提供 足够 的 支持 。 目 前 提供 这 
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些 支持 的 浏览 器 有 IE 5.0 及 以 上 版 本 、Mozilla 1.0、NetScape 7 及 以 上 版 本 。Mozilla 虽然 也 支持 Ajax， 
但 是 提供 XMLHttpRequest 对 象 的 方式 不 一 样 。 所 以 ， 使 用 Ajax 的 程序 必须 测试 其 针对 各 个 浏览 器 的 
兼容 性 。 

2. XMLHttpRequest 对 象 封 装 

Ajax 技术 的 实现 主要 依赖 于 XMLHttpRequest 对 象 ， 但 是 在 调用 其 进行 异步 数据 传输 时 ， 由 于 
XMLHttpRequest 对 象 的 实例 在 处 理事 件 完成 后 就 会 被 销毁 ， 所 以 如 果 不 对 该 对 象 进行 封装 处 理 ， 在 下 
次 需要 调用 它 时 就 得 重新 构建 ， 而 且 每 次 调用 都 需要 写 一 大 段 的 代码 ， 使 用 起 来 很 不 方便 。 不 过 ， 现 
在 很 多 开源 的 Ajax 框架 都 提供 了 对 XMLHttpRequest 对 象 的 封装 方案 ， 其 详细 内 容 这 里 不 作 介绍 ， 读 
者 可 参考 相关 资料 。 

3. 性 能 问题 

由 于 Ajax 将 大 量 的 计算 从 服务 器 移 到 了 客户 端 ， 这 就 意味 着 浏览 器 将 承受 更 大 的 负担 ， 而 不 再 是 
只 负责 简单 的 文档 显示 。 由 于 Ajax 的 核心 语言 是 JavaScript， 而 JavaScript 并 不 是 以 高 性 能 而 知名 ， 另 
外 ，JavaScript 对 象 也 不 是 轻 量 级 的 ， 特 别 是 DOM 元 素 耗费 了 大 量 的 内 存 ， 因 此 ， 如 何 提高 JavaScript 
代码 的 性 能 对 于 Ajax 开发 者 来 说 尤为 重要 。 下 面 介绍 3 种 优化 Ajax 应 用 执行 速度 的 方法 : 

加 ”优化 for 循环 。 

回 将 DOM 节点 附加 到 文档 上 。 

回 ”尽量 减少 点 “.” 号 操作 符 的 使 用 。 

4. 中 文 编码 问题 

Ajax 不 支持 多 种 字符 集 ， 它 默认 的 字符 集 是 UTF-8， 所 以 在 应 用 Ajax 技术 的 程序 中 应 及 时 进行 编 
码 转 换 ， 和 否则 程序 中 出 现 的 中 文字 符 将 变 成 乱码 。 一 般 来 说 ， 以 下 两 种 情况 会 产生 中 文 乱码 。 

回 PHP 发 送 中 文 、Ajax 接收 。 只 需 在 PHP 顶部 添加 如 下 语句 。 

header('Content-type: text/html:charset=GB2312'): // 指 定 发 送 数据 的 编码 格式 


XMLHttp 会 正确 解析 其 中 的 中 文 。 
回 Ajax 发 送 中 文 、PHP 接收 。 这 个 比较 复杂 ，Ajax 中 先 用 encodeURIComponent 对 要 提交 的 中 
文 进行 编码 ， 在 PHP 页 中 添加 如 下 代码 。 


$GB2312string=iconv( 'UTF-8', "gb2312//I{GNORE’ . SRequestAjaxString): 
PHP 选择 MySQL 数据 库 时 ， 应 用 如 下 语句 设置 数据 库 的 编码 类 型 。 


mysql_query("set names gb2312"): 


23.5 实 战 


Ajax 作为 Web 2.0 时 代 的 关键 技术 , 已 经 被 广泛 地 应 用 , 并 且 很 多 组 织 已 经 推出 基于 Ajax 的 框架 ， 
如 jQuery 就 是 非常 快捷 、 方 便 的 Ajax 框架 ， 使 用 jQuery 技术 可 以 用 简单 的 几 行 代码 完成 非常 复杂 的 
Ajax 交互 。 本 节 将 通过 具体 实例 讲解 Ajax 技术 的 应 用 。 
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是 否 为 空 检测 按钮 ， 代 码 如 下 。 


<form name="form register"> 
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用 户 名 : <input type="text" id="usermmame" name="usemame" size="20" />&nbsp; 
<input type="button" value=" 查 看 用 户 名 是 否 被 占用 " 
onclick="javascript:chkUsername(form register.username.value)" /> 


</form> 
(3) 建立 与 MySQL 数据 库 的 连接 ， 选 择 数 据 库 并 设置 字符 集 。 
<?php 
$host ="127.0.0.1'; //MySQL 数据 库 服 务 器 地 址 
SuserName = root'; // 用 户 名 
Spassword = 'root'; /密码 


$connID = mysql_connect($host, $userName, $password); 
mysql_select_db('db_database23', SconnID): 


mysql_query('set names gbk'); // 设 置 字符 集 
2> 


/建立 与 数据 库 的 连接 
/选择 数据 库 


(4) 建立 chk.php 文件 ， 该 文件 中 的 代码 用 于 判断 客户 端 通过 GET 方法 提交 的 用 户 名 的 值 ， 并 判 
断 该 值 是 否 存 在 ， 如 果 存在 则 返回 “y”， 否 则 返回 “n”。 


<2php 


Tequire_once 'conn.php'; // 包 含 数据 库 连 接 文 件 
$sql = mysql_query("select id username from tb_user where username=".trim($_GET['username'])."", $connID); 
// 执 行 查询 
Sresult = mysql_fetch_array($sq)); 
if(Sresult) { // 判 断 用 户 名 是 否 存 在 
echo y'; 
} else{ 
echo n'; 
} 
?> 


运行 上 述 实例 ， 结 果 如 图 23.5 所 示 ， 在 用 户 名 文本 框 中 随便 输入 一 个 用 户 名 ， 然 后 单 击 “ 查 看 用 
户 名 是 否 被 占用 ”按钮 ， 在 不 刷新 页 面 的 情况 下 即 可 弹出 该 用 户 名 是 否 被 占用 的 提示 信息 。 
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图 23.5 检测 用 户 名 是 否 被 占用 
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23.5.2 在 PHP 中 应 用 Ajax 技术 实现 博客 文章 类 别 添加 


馈 m 视频 讲解 ， 光盘 \TM\VideoW23\ 在 PHP 中 应 用 Ajax 技术 实现 博客 文章 类 别 添加 .exe 

传统 方式 中 ， 通 过 POST 方法 提交 表单 中 的 数据 ， 页 面 需 要 刷新 ， 而 使 用 Ajax 技术 通过 POST 方 
法 提交 数据 ， 不 需要 刷新 页 面 即 可 实现 与 服务 器 的 交互 ， 这 样 可 以 有 效 减少 刷新 页 面 的 等 待 时 间 。 

例 23.5 使 用 Ajax 技术 通过 POST 方法 添加 文章 类 别 。 (实例 位 置 ， 光盘 \TM\Instances\23\5) 

本 实例 的 实现 步骤 如 下 : 

(1) 建立 类 别 信 息 录入 表单 。 与 传统 的 表单 相 比 ， 使 用 Ajax 技术 通过 POST 方法 提交 数据 时 ， 

不 需要 在 客户 端 表单 中 使 用 <form> 标 记 ， 数 据 类 型 通过 XMLHttpRequest 对 象 的 setRequestHeader() 方 
法 设 定 。 类 别 录 入 表单 结构 如 表 23.2 所 示 。 


表 23.2 类别 录入 表单 的 表单 元 素 


FEY 机 肌 


ED 文本 域 博客 类 别 
区] 文本 域 e 发 布 人 
口 提交 按钮 type="button" value=" 保 存 " onclick="saveType(typename.value, 提交 按钮 


username.value)" 


(2) 建立 funijs 脚本 文件 ， 在 该 文件 中 编写 用 于 将 客户 端 录 入 的 数据 通过 POST 方法 提交 到 服务 
器 的 Ajax 代码 ， 如 下 所 示 。 
function saveType(typename, username){ 


if(typename=—"){ 1/ 判断 博客 类 别 是 否 为 空 
alert( 请 输入 类 别名 称 ! "); 
}else if(usemame=——"){ /判断 用 户 名 是 否 为 空 
alert(' 请 输入 用 户 名 ! ): 
}else{ 
Var xmlObj: // 定 义 XMLHttpRequest 对 象 
var urlData = "typename="+typename+"&username=—"+username: 1/ 指 定 要 发 送 的 数据 
这 window.ActiveXObjecb{ 


// 判 断 浏览 器 是 否 支持 ActiveXObiject 组 件 ， 如 果 支 持 则 通过 ActiveXObject 方式 创建 XMLHttpRequest 对 象 
xmlObj = new ActiveXObject("Microsoft. XMLHTTP"): 
}else if(window.XMLHttpRequest){ 
// 如 果 浏 览 器 不 支持 ActiveXObject 组 件 ， 则 使 用 XMLHttpRequest 组 件 创建 XMLHttpRequest 对 象 
xmlObj = new XMLHttpRequestO: 
bs 


xmlObj.onreadystatechange = callBackFun: /指定 回调 函数 
xmlObj.open("POST", "saveType.php", true): /指定 提交 方法 和 页 面 
XmlObj.setRequestHeader("Content-Type", "application/x-www-form-urlencoded;"): 

/指定 发 送 数据 库 类 型 
xmlObj.send(urlData): /指定 发 送 的 数据 
function callBackFunO{ /定义 回调 函数 

if(xmlObj readyState — 4 && xmlObj status 一 200){ 

/如 果 服 务 器 端 返 回 内 容 并 无 错误 发 生 
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这 xmlObjresponseText — 'y){ // 潮 断 保存 是 否 成 功 ， 并 给 出 提示 
alert( 类 别 添加 成 功 ! "); 

jelse{ 
alert( 类 别 添 加 失败 ! "); 

} 


} 


上 述 代 码 中 ， 首 先 判 断 是 否 已 经 录入 了 博客 类 别 信 息 ， 并 给 出 相关 提示 ， 之 后 定义 并 创建 
XMLHttpRequest 对 象 , 使 用 该 对 象 的 onreadystatechange 属性 指定 回调 函数 , open 方法 指定 通过 POST 
方法 提交 以 及 提交 页 面 ，setRequestHeader( 方 法 指定 发 送 数据 类 型 ，send( 方 法 指定 要 发 送 的 数据 。 在 
回调 函数 中 根据 返回 参数 判断 类 别 是 否 保存 成 功 ， 并 通过 提示 窗口 给 出 相应 的 提示 信息 。 

(3) 编写 conn.php 文件 ， 该 文件 中 的 代码 用 于 实现 与 MySQL 数据 库 的 连接 ， 并 设置 字符 集 ， 代 
码 如 下 。 


<?php 

$host ="127.0.0.1'; /MySQL 数据 库 服 务 器 地 址 
SuserName = Toot': /用 户 名 

$password = 'Toot': /密码 

S$connID = mysql_connect($host, SuserName, Spassword): // 建 立 与 数据 库 的 连接 
mysql_select_db('db_database23' SconnID): 1/ 选择 数据 库 
mysql_query('set names gbk'); // 设 置 字符 集 

eo 


为 了 防止 数据 库 的 中 文 内 容 发 送 乱 码 ， 在 完成 数据 选择 后 通过 mysql_query0 函 数 执行 SQL 命令 ， 
设置 数据 所 使 用 的 字符 集 为 GBK 编码 。 
(4) 接收 通过 POST 方法 提交 的 内 容 ， 并 将 博客 类 别 等 相关 内 容 保存 到 数据 库 中 。 


<?php 
Tequire_once 'conn.php'; // 包 含 数据 库 连 接 文件 
Stypename = iconv('utf-8', 'gbk',$ POST['typename']): // 将 类 别名 称 由 UTF-8 编码 转变 为 GBK 编码 
$username = iconv("utf-8', 'gbk', $ POST["username']); 。“”// 将 用 户 名 称 由 UTF-8 编码 转变 为 GBK 编码 
这 mysql_query("insert into tb_type(typename, usemame, addtime) Values(".Stypename.", .$usermmame.", ".date('Y-m-d 
H:i:s).")", $connID)){ // 将 数据 库 保存 到 数据 库 中 

echo y'; 
}else{ 

echo nm’; 
} 
?> 


上 述 代 码 中 ， 使 用 require_once 语句 包含 conn.php 文件 从 而 建立 与 数据 库 的 连接 ， 由 于 Ajax 在 通 
过 POST 方法 提交 数据 时 默认 采用 UTF-8 编码 ， 所 以 在 接收 提交 的 相关 信息 后 需要 使 用 iconvO 函 数 将 
所 接收 的 内 容 由 UTF-8 编码 转换 为 GBK 编码 ， 完 成 转 码 后 使 用 mysql_queryO 函 数 将 类 别 信息 保存 到 
数据 库 中 ， 如 果 成 功 保存 则 输出 Y， 否 则 输出 n。 

运行 本 实例 ， 结 果 如 图 23.6 所 示 ， 在 “请 输入 博客 类 别 ” 和 “发 布 人 ”文本 框 中 填写 相关 信息 后 ， 
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S$.get("returnpc.php?flag=p", null, function(data){ 
// 向 服务 器 发 送 GET 请 求 ， 获 取 省 份 的 值 ， 并 将 结果 追加 到 “省 份 ”下 拉 列 表 框 中 


$("#p").append(data): 
D: 
S$("#c").css("display","none"): // 初 始 状 态 使 “城市 ”下 拉 列 表 框 不 可 见 
3("#p").change(functionO{ // 为 “省 份 ” 下 拉 列 表 框 增加 改变 事件 
if(s("#p").val0—""){ // 在 未 选择 省 份 的 情况 下 ， 使 “城市 ”下 拉 列 表 框 不 可 见 
S$("#c").css("display","none"); 
}else{ 


S$.get("returnpc.php?flag=cé&p="+$("#p").val|. null function(data) { 
/如 果 选 择 了 某 省 份 ， 则 向 服务 器 改 关 GET 请 求 ， 使 用 回调 函数 为 “城市 ”下 拉 列 表 框 赋 值 ， 并 使 “城市 ”下 
拉 列 表 框 可 见 
S$("#c").css("display"."™"): 
$("#c").emptyO; 
S$("#c").append(data); // 将 数据 追加 到 “城市 ”下 拉 列 表 框 
六 


上 述 代码 中 ， 主 要 使 用 Ajax 的 jQuery 框架 ， 没 有 jQuery 框架 基础 的 读者 可 能 不 容易 理解 上 述 代 
码 ， 下 面 对 该 内 容 进 行 介绍 。 

$(document).ready0 表 示 在 页 面 载 入 时 所 执行 的 操作 ,是 window.load 注册 事件 的 替代 方法 。 在 ready 
方法 中 使 用 一 个 匿名 函数 作为 参数 ， 所 有 初始 操作 都 在 该 匿名 函数 中 定义 。 

$.get0 方 法 用 于 向 服务 器 发 送 GET 请 求 ， 该 方法 的 语法 格式 如 下 : 

S.get(url, data, callback); 


其 中 ,参数 url 为 待 载 入 页 面 的 URL 地 址 ，data 为 要 向 服务 器 端 发 送 的 数据 ，callback 为 载 入 成 功 
时 的 回调 函数 。 可 以 发 现 ， 如 果 直 接 使 用 Ajax 向 服务 器 发 送 GET 请 求 ， 需 要 编写 多 行 代码 才能 实现 ， 
而 使 用 jQuery 框架 只 需 一 个 方法 即 可 实现 ， 所 以 jQuery 确实 为 程序 开发 带 来 了 极 大 的 方便 。 在 回调 函 
数 中 定义 如 下 代码 : 


S("#p").append(data) 


其 中 ,$(" 元 ") 用 来 获取 HTML 页 面 中 ID 为 p 的 元 素 的 引用 , 相当 于 document.getElementById("p")， 
append() 方 法 用 于 向 “省 份 ” 下 拉 列 表 框 中 添加 列表 项 。 
$("#p").change0) 方 法 为 “省 份 ” 下 拉 列 表 框 的 change 事件 ， 当 选择 下 拉 列 表 框 中 的 选项 时 触发 该 
事件 。 在 “省 份 ”下 拉 列 表 框 的 change 事件 中 向 服务 器 发 送 GET 请 求 ， 并 在 回调 函数 中 将 服务 器 返回 
的 值 追 加 到 “城市 ”下 拉 列 表 框 中 。 
(4) 编写 用 于 返回 客户 端 请 求 的 服务 器 端 代码 ， 根 据 客户 端 传递 参数 flag 的 值 判断 返回 省 份 信息 
还 是 城市 信息 ， 之 后 从 省 份 数组 或 城市 数组 中 提取 要 返回 的 内 容 并 返回 。 


加 


<2php 
Tequire_once 'pc.php': // 包 含 省 份 数组 和 城市 数组 
Sflag =$_GET['flag’]: // 用 于 区 分 是 返回 省 份 信息 还 是 返回 城市 信息 
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S$str=""; 
if(sflag 一 D){ // 如 果 参 数 flag 的 值 为 p， 则 返回 省 份 信息 
for($i=0: $i<count($p): SiHH{ // 通 过 循环 整理 所 有 要 追加 到 “省 份 ”下 拉 列 表 框 的 内 容 
$str="<option value=\"".iconv('gbk’,'"utf-8',$p[$i])."\">".iconv(‘gbk',"utf-8'.$p[$i])."</option>"; 
} 
echo $str: /输出 要 返回 的 参数 
jelse{ 
Sindex = amay_search($_GET[p], Sp): // 提 取 所 选择 的 省 份 在 省 份 数组 中 对 应 的 键 值 
for($j=0;: $j<count($c[Sindex]): Sj+HH){ // 通 过 循环 整理 所 有 要 追加 到 “城市 ”下 拉 列 表 框 的 内 容 
$str.= "<option value=\"".iconv('‘gbk','utf-8',$c[S$index][$j])."\">".iconv('gbk','utf-8',$c[Sindex][$j])."</option>":; 
} 
echo $str: // 输 出 要 返回 的 参数 
} 
?> 


< 注意 : 为 了 防止 返回 的 信息 乱码 ， 需 要 使 用 iconv0 〇 函数 将 GBK 编码 转换 为 UTF-8 编码 。 


运行 上 述 实例 , 结果 如 图 23.7 所 示 。 默认“ 城市 ”下 拉 列 表 框 不 可 见 ， 当 选择 某 省 份 时 会 显示 “ 城 
市 ”下 拉 列 表 框 ， 并 将 该 省 份 所 包括 的 城市 显示 在 “城市 ”下 拉 列 表 框 中 。 


[ 酬 司 [ 梧 习 
EE 有 4 
图 23.7 选择 地 区 


23.6 本 章 小 结 


本 章 从 Ajax 技术 的 基本 概念 开始 ， 采 用 循序 渐进 的 方式 介绍 了 Ajax 技术 的 开发 模式 、 特 性 及 其 
组 成 部 分 , 并 重点 介绍 了 Ajax 技术 的 核心 XMLHttpRequest 对 象 ， 以 及 编写 基本 的 Ajax 程序 的 步骤 和 
思路 , 最 后 通过 具体 实例 巩固 本 章 所 介绍 的 内 容 , 尤其 在 本 章 最 后 使 用 一 个 简单 的 实例 介绍 了 基于 Ajax 
技术 的 jQuery 框架 的 使 用 方法 。 通 过 本 章 的 学 习 ， 读 者 可 以 理解 Ajax 技术 的 概念 和 基本 Ajax 应 用 的 
制作 方法 ， 能 够 在 此 基础 上 进一步 深入 学 习 Ajax 技术 尤其 是 jQuery 框架 的 使 用 方法 。 


23.7 实战 练习 


1. 向 服务 器 上 传 文件 或 从 服务 器 下 载 文件 时 ， 经 常会 等 待 很 长 时 间 ， 为 了 显示 上 传 或 下 载 进度 ， 
可 以 使 用 进度 条 来 显示 。 要 求 用 jQuery 框架 制作 如 图 23.8 所 示 的 进度 条 。 (答案 位 置 ， 光盘 \TM 
Instances\23\7) 

2. 采用 图 表 的 形式 显示 大 量 的 统计 数据 非常 直观 ， 以 往 在 页 面 中 显示 的 图 表 都 是 静态 的 ， 如 果 将 
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如 果 是 第 一 次 或 者 模板 已 


如 果 不 是 第 一 次 或 者 模 | | 经 改变 , 则 重新 使 用 原文 件 


板 未 改变 则 使 用 原文 件 


输出 网 页 
24.1 Smarty 模板 引擎 运行 流程 图 


24.2 Smarty 的 安装 配置 


铭 m 视频 讲解 ， 光盘 \TMNVideo\24\Smarty 的 安装 配置 .exe 
24.2.1 Smarty 下 载 和 安装 


PHP 没有 内 置 Smarty 模板 类 ， 需 要 单独 下 载 和 配置 ， 并 且 Smarty 要 求 服务 器 上 的 PHP 版 本 最 低 
为 4.0.6。 用 户 可 以 通过 http://smarty.php.,net/download.php 网 站 下 载 最 新 的 Smarty 压缩 包 。 本 章 使 用 的 
版 本 是 Smarty-2.6.19。 

将 压缩 包 解压 后 ， 有 一 个 libs 目录 ， 其 中 包含 了 Smarty 类 库 的 核心 文件 ， 包 括 smarty.class.php、 
smarty_Compiler.class.php、config File.class.php 和 debug.tpl4 个 文件 ， 还 有 internals 和 plug-ins 两 个 目 
录 。 将 libs 目录 复制 到 服务 器 根 目录 下 ， 并 为 其 重新 命名 。 一 般 该 目录 的 名 称 为 smarty、class 等 ， 这 
里 将 libs 文件 夹 重 新 命名 为 Smarty。 至 此 ，Smarty 模板 安装 完毕 。 


< 抽 注意 ; 凡是 在 后 面 的 章节 中 提 到 Smarty 类 包 、Smarty 目录 等 ， 都 是 这 个 重新 命名 后 的 Smarty 目录 ， 
即 原 libs 目录 。 


24.2.2 Smarty 配置 


出 色 地 完成 Smarty 的 配置 工作 ， 是 应 用 Smarty 模板 引擎 的 关键 。 
(1) 确定 Smarty 目录 的 位 置 。 因 为 Smarty 类 库 是 通用 的 ， 每 一 个 项 目 都 可 能 会 使 用 到 它 。 所 以 
将 Smarty 放 到 根 目 录 下 。 因 为 本 章 的 所 有 程序 都 放 在 tm/sl/24/ 文 件 夹 下 , 所 以 将 /24/ 作 为 临时 的 根 目录 ， 
Smarty 就 放 到 这 个 目录 下 。 
(2) 新 建 4 个 目录 templates、templates c、configs 和 cache。 因 为 目录 templates 存放 的 是 项 目的 模 
板 ， 所 以 有 人 喜欢 将 templates 放 到 Smarty 目录 外 。 这 两 种 方法 没什么 区 别 ， 只 要 设置 的 路 径 正 确 即 可 。 
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(3) 创建 配置 文件 。 如 果 要 应 用 Smarty 模板 ， 就 一 定 要 包含 Smarty 类 库 和 相关 信息 。 将 配置 信 

息 写 到 一 个 文件 中 ， 用 的 时 候 只 要 包含 配置 文件 就 可 以 。 这 里 要 注意 一 点 ， 配 置 文件 中 要 使 用 绝对 路 
径 ， 因 为 服务 器 不 会 知道 文件 在 第 几 层 目录 中 被 调用 。 配 置 文件 完成 后 ， 保 存 到 根 目录 下 。 不 要 忘记 
本 章 中 所 指 的 根 目录 是 /24/。 配 置 文件 config php 的 代码 如 下 。 

<?php 

必定 义 服务 器 的 绝对 路 径 */ 

define(BASE PATH'F:\AppSerwwwwAN): 

必定 义 Smarty 目录 的 绝对 路 径 */ 

define(SMARTY PATH'"IM\sN24\Smarty\): 

让 ”加载 Smarty 类 库 文件 */ 

Tequire BASE PATH.SMARTY PATH.'Smarty.class.php'; 

启 ”实例 化 一 个 Smarty 对 象 */ 

$smarty = new Smarty: 

族 定义 各 个 目录 的 路 径 。 */ 

S$smarty->template dir =BASE PATH.SMARTY PATH.'templates/: 

S$smarty->compile dir= BASE PATH.SMARTY PATH.'templates c/'; 

S$smarty->config dir = BASE PATH.SMARTY PATH.configs/: 

$smarty->cache dir =BASE PATH.SMARTY PATH.cache/': 

上 # 定义 定 界 符 */ 

/l/Ssmarty->left_delimiter = "<{"; 

l/Ssmarty->right_delimiter = "}>"; 

?> 


上 述 配 置 文件 的 参数 说 明 如 下 。 
回 BASE PATH: 指定 服务 器 的 绝对 路 径 。 


[说 明 ; 指定 服务 器 绝对 路 径 的 目的 是 找到 Smarty 文件 夹 在 服务 器 中 的 存储 位 置 。 这 里 有 两 种 方法 
可 以 使 用 : 第 一 种 ， 直 接 指 定 绝 对 路 径 ， 如 F:\AppServWwww\\， 使 用 这 种 方法 来 指定 服务 器 
的 绝对 路 径 , 一 旦 服务 器 的 绝对 路 径 发 生 更 改 , 就 必须 要 修改 配置 文件 ， 否则 程序 就 会 运行 
出 错 ; 第 二 种 ， 通 过 全 局 变量 $ SERVER[DOCUMENT ROOT'] 来 获取 服务 器 的 绝对 路 径 ， 
使 用 该 方法 不 会 因为 服务 器 路 径 的 更 改 而 影响 到 程序 的 执行 .推荐 使 用 第 二 种 方法 定义 服务 
器 的 绝对 路 径 。 

SMARTY PATH: 指定 Smarty 目录 的 绝对 路 径 。 

require(): 加 载 Smarty 类 库 文件 Smarty.class.php。 

$smarty: 实例 化 Smarty 对 象 。 

$smarty->template_dir: 定义 模板 目录 存储 位 置 。 

$smarty-> compile_dir: 定义 编译 目录 存储 位 置 。 

$smarty-> config dir: 定义 configs 文件 存储 位 置 。 

$smarty-> cache_dir: 定义 模板 缓存 目录 。 

$smarty->left_delimiter: 定义 Smarty 使 用 的 开始 定 界 符 。 

$smarty->right_delimiter: 定义 Smarty 使 用 的 结束 定 界 符 。 

有 关 定 界 符 的 使 用 ， 开 发 者 可 以 指定 任意 的 格式 。 也 可 以 不 指定 定 界 符 ， 使 用 Smarty 默认 的 定 界 


办 办 办 办 办 欠 凶 
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符 “{” 和 “}”。 
到 此 ，Smarty 的 配置 讲解 完毕 。 


24.2.3 ”第 一 个 Smarty 程序 


铬 m 视频 讲解 ， 光盘 \TMNVideo\24\ 第 一 个 Smarty 程序 .exe 
介绍 Smarty 的 下 载 、 安 装 和 配置 方法 后 ， 接 下 来 就 创建 一 个 Smarty 程序 ， 通 过 具体 的 操作 来 了 
解 Smarty 的 应 用 。 
例 24.1 创建 第 一 个 Smarty 应 用 实例 ,初步 了 解 Smarty 的 使 用 过 程 。( 实 例 位 置 :光盘 \TMNInstances\ 
24\1) 
(1) 在 服务 器 根 目录 下 的 /tm/sl/24/ 文 件 夹 下 ， 新 建 一 个 文件 夹 ， 命 名 为 1。 
(2) 复制 Smarty 到 目录 1 下 。 在 Smarty 目录 下 新 建 4 个 目录 ， 分 别 是 templates、templates_c、 
configs 和 cache。 此 时 ， 例 24.1 的 目录 结构 如 图 24.2 所 示 。 


- 例 24. 1 主 目录 


phy 
Sarty Compiler class ph 
Bindex php 


24.2 Smarty 包 的 目录 结构 


(3) 新 建 一 个 .html 静态 页 ， 输 入 数据 。 输 入 完毕 后 将 文件 保存 到 刚刚 新 建 的 templates 目录 下 ， 
并 命名 为 index.tpl。 实 例 代码 如 下 。 


<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html: charset=gb2312" /> 
<title>{ Stitle }</title> 
</head> 
<body> 
{Scontent} 
</body> 
</html> 


[如 说 明 : 代码 中 加 粗 的 部 分 就 是 Smarty 标签 ， 大 括号 “{}” 为 标签 的 定 界 符 ，$title 和 $content 为 变量 。 
(4) 回 到 上 级 目录 ， 在 目录 /1/ 下 新 建 一 个 .php 文件 ， 使 用 Smarty 变量 和 方法 对 文件 进行 操作 ， 
输入 完毕 后 保存 为 index.php， 代 码 如 下 。 
<?php 


六 ”定义 服务 器 的 绝对 路 径 */ 
define(BASE PATH'.S$ SERVER[DOCUMENT ROOT]): 
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类 库 也 自然 被 分 成 两 部 分 来 使 用 ， 即 Smarty 模板 设计 和 Smarty 程序 设计 。 两 部 分 内 容 既 相互 独立 ， 
同时 也 有 一 部 分 共通 。 本 节 首 先 来 学 习 Smarty 模板 设计 。 


24.3.1 Smarty 模板 文件 


Smarty 模板 文件 是 由 一 个 页 面 中 所 有 的 静态 元 素 ， 加 上 定 界 符 “{…}” 组 成 的 。 模 板 文件 统一 存 
放 的 位 置 是 templates 目录 下 (模板 文件 的 存储 位 置 可 以 在 配置 文件 中 指定 , 可 以 根据 个 人 习惯 而 定 〉。 
模板 中 不 允许 出 现 PHP 代码 段 。Smarty 模板 中 的 所 有 注释 、 变 量 、 函 数 等 都 要 包含 在 定 界 符 内 。 


24.3.2 注释 


Smarty 中 的 注释 和 PHP 注释 类 似 ， 都 不 会 显示 在 源 代码 中 。 注 释 包含 在 两 个 星 号 “* ”中 间 ， 格 
式 如 下 : 


{* 这 是 注释 分 
24.3.3 ”变量 


Smarty 中 的 变量 来 自 以 下 3 个 部 分 : 

回 来 自 PHP 页 面 中 的 变量 ， 也 就 是 assign0 方 法 传 过 来 的 变量 。 

使 用 方法 和 在 PHP 中 是 相同 的 ， 也 需要 使 用 “$” 符 号 。 略 有 不 同 的 是 对 数组 的 读 取 。Smarty 中 
读 取 数 组 有 两 种 方法 。 一 种 是 通过 索引 获取 ， 与 PHP 中 相似 ， 可 以 是 一 维 ， 也 可 以 是 多 维 ， 另 一 种 是 
通过 键 值 获取 数组 元 素 ， 这 种 方法 的 格式 与 以 前 接触 过 的 不 同 ， 使 用 符号 “.” 作 为 连接 符 ， 数 组 $arr = 
array {'object' => 'book','type' => 'comptuerunit => ' 本 '}, 如 果 想 得 到 type 的 值 ,表达 式 的 格式 为 $arr.type。 
这 个 格式 同样 适用 于 二 维 数组 。 

例 24.2 使 用 上 述 两 种 方法 读 取 数 组 值 ， 代 码 如 下 : 实例 位 置 ， 光盘 \IM\Instances\24\2) 

Smarty/templates/2/index.tpl 文件 

<html> 

<head> 


{* 页 面 的 标题 变量 Stile *} 
<title>{ $title }</title> 


{* 使 用 索引 取得 数组 的 第 一 个 元 素 值 *} 
图 书 类 别 : { $ar[0] }<br /> 

{* ”使 用 键 值 取 得 第 二 个 数组 元 素 值 外 

图 书 名 称 : { $arr.name }<br /> 

{* ”使 用 键 值 取得 二 维 数组 的 元 素 值 分 

图 书 单价 : { $arr.unit_price.price }/{ $arr.unit_price.unit } 
</body> 


479 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


第 24 章 “Smarty 模板 技术 


运行 结果 如 图 24.5 所 示 。 
从 配置 文件 中 读 取 数 据 。Smarty 模板 也 可 以 通过 配置 文件 来 赋值 。 对 于 PHP 开发 人 员 来 说 ， 
对 配置 文件 的 使 用 从 安装 服务 器 就 开始 了 ， 对 文件 的 格式 也 有 了 一 个 初步 的 了 解 。 调 用 配置 
文件 中 变量 的 格式 有 以 下 两 种 : 
> 使 用 “#” 号 。 将 变量 名 置 于 两 个 “#” 号 中 间 ， 即 可 像 普通 变量 一 样 调用 配置 文件 内 容 。 
> ”使 用 保留 变量 中 的 $smarty_config 来 调用 配置 文件 。 

例 24.4 通过 上 面 两 种 方法 来 调用 配置 文件 4.conf 的 内 容 ， 代 码 如 下 : (实例 位 置 : 光盘 \TM\ 
Instances\24\4) 


al 


configs/4/4.conf 文 件 

title = "调用 配置 文件 " 

bgcolor = "#f0f0f0" 

border = "5" 

type = "计算 机 类 

name= "PHP 从 入 门 到 精通 " 

templates/04/infex.tpl 文件 

{ config load file="4/4.conf' } 

<html> 

<head> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 

<title> {#title#}</title> 

</head> 

<body bgcolor=" {#bgcolor#}"> 

<table border=" {#border#}"> 

<t> 
<td> {$smarty.config.type}</td> 
<td> {$smarty.config.name}</td> 


index.php 文件 
<2php 
include_once '../config.php'; 
S$smarty->display('4/index.tpl"); 
ea 


了 结果 如 图 24.6 所 示 。 


ts =l9)xl 蛋 汉 用 配置 文件 ~ Wicroseft Iatersee iolxl 
收成 W) 工具 UD) 各” 诗 | 文件 四 久生 二 由 RW 工具 UD | 人 
地 址 四 ) SEE W127.0.0 /tal/24/3/ 司 | 加 苇 到 | 钴 本 罗 | 瑞 址 加 | 乱 http /1127.0.0. yevay2v 司 | EE 
pine 是 PE ET 习 
当前 时 间 为 : 1241077775 到 
Eg i | |@ 5 点 4 SE 


图 24.5 Smarty 保留 变量 图 24.6 调用 配置 文件 


24.3.4 ”修饰 变量 
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24.3.3 节 中 介绍 了 如 何在 Smarty 模板 中 调用 变量 。 但 有 的 时 候 ， 不 仅 要 取得 变量 值 ， 还 要 对 变量 
进行 处 理 。 变 量 修饰 的 一 般 格式 如 下 : 


{variable_ namelmodifer name: parameterl:*…} 


加 ”variable_name 为 变量 名 称 。 

回 modifer_ name 为 修饰 变量 的 方法 名 。 变 量 和 方法 之 间 使 用 符号 “|” 分 隔 。 
加 ”parameterl 是 参数 值 。 如 果 有 多 个 参数 ， 则 使 用 “:” 分 开 。 

Smarty 提供 了 修饰 变量 的 方法 。 常 用 的 方法 如 表 24.2 所 示 。 


方 法 名 
capitalize 
count characters:true/false 
cat: "characters" 
date format: "WY-%M-%D" 


default: "characters" 
escape: "value" 


lower 

nl2br 
regex_replace:"parameterl":"value2" 
Teplace: "valuel":"value2" 

string format: "value" 

strip_tags 

Upper 


表 24.2 修饰 变量 的 常用 方法 和 说 明 
说 明 
首 字 母 大 写 
变量 中 的 字符 串 个 数 。 如 果 后 面 有 参数 tue， 则 空格 也 被 计算 ， 否 则 忽略 空格 
将 cat 中 的 字符 串 添加 到 指定 字符 串 的 后 面 
格式 化 日 期 和 时 间 。 等 同 于 PHP 中 的 srftime0 函 数 
设置 默认 值 。 当 变量 为 空 时 ， 将 使 用 default 后 面 的 默认 值 
用 于 字符 串 转 码 。value 值 可 以 为 html、htmlall、url、quotes、hex、hexentity 和 
javascript， 默 认为 html 
将 变量 字符 串 改 为 小 写 
所 有 的 换行 符 将 被 替换 成 <br />， 功 能 同 PHP 中 的 nl2br0 函 数 一 样 
正则 替换 。 用 value2 替换 所 有 符合 parameterl 标准 的 字 串 
替换 。 使 用 value2 替换 掉 所 有 valuel 
使 用 value 来 格式 化 字符 串 。 如 果 value 为 %d， 则 字符 串 被 格式 化 为 十 进 制 数 
去 掉 所 有 的 html 标签 
将 变量 改 为 大 写 


在 对 变量 进行 修饰 时 ， 不 仅 可 以 单独 使 用 上 面 的 方法 ， 还 可 以 同时 使 用 多 个 。 在 每 个 方法 之 间 使 


用 “|” 分 隔 即 可 。 


例 24.5 ”使 用 表 24.2 中 的 几 个 方法 来 修饰 字符 串 。 其 他 方法 的 使 用 ， 读 者 可 以 自行 练习 。 实 例 代 
码 如 下 : 《〈 实 例 位 置 ， 光 盘 \TMNInstances\24\S) 


Templates/S/index.tpl 文件 
<html> 
<head> 


<meta http-equiv="Content-Type" content="text/html: charset=gb2312" /> 


<title> {$title} </title> 


<link rel="stylesheet" href="../css/style.css" /> 


</head> 
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<body> 
原文 : {Sstr} 


> 

变量 中 的 字符 数 〈 包 括 空 格 ) : {Sstrjcount_characters:true} 
<br 亡 

使 用 变量 修饰 方法 后 : {Sstrlnl2brjupper} 


<?php 
include_once "../config.php"; 
$strl =' 这 是 一 个 实例 。'; 
$str2 = " 图 书 -> 计算 机 类 ->phpu 书 名 : 《php 从 入 门 到 精通 》"; 
$str3 = " 价格: 圣 59/ 本 。": 
$smarty->assign("title',' 使 用 变量 修饰 方法 "); 
$smarty->assign(str,$str1.$str2.$str3.$str4): 
S$smarty->display('5/index.tpl"): 

?> 


运行 结果 如 图 24.7 所 示 。 


文件 四 “ 编 姐 G)。 坦 看 00 收音 从 ) 工具 上 帮助 0 


殉 量 中 此 地 作 数 ( 包 所 空格 ) : 市 
信用 于 量 作 户 方 法 后: 这 是 一 人 实例 - 
9 蔬 - 其 机 次->PIE 
:PEAAT RE) 
EE 


24.7 ”使 用 变量 修饰 方法 


24.3.5 ”流程 控制 


Smarty 模板 中 的 流程 控制 语句 包括 if…elseif…else 条 件 控制 语句 和 foreach、section 循环 控制 语句 。 
1.，if.…elseif…else 语句 
让 条 件 控制 语句 的 使 用 和 PHP 中 的 这 大 同 小 异 。 需 要 注意 的 是 ， 寺 必须 以 /if 为 结束 标记 。 寺 语句 
的 格式 如 下 : 
{站 条 件 语句 1} 
语句 1 
{elseif 条 件 语句 2} 
语句 2 
{else} 
语句 3 
{请 


上 述 条 件 语句 中 ,除了 可 以 使 用 PHP 中 的 <、>、=、 上 等 常见 运算 符 外 ， 还 可 以 使 用 eq、ne、neq、 
gt、 lt lte、 le、 gte、 ge、 iseven、 isodd、 isnoteven、 isnotodd、 not、 mod、 divby、 even by、odd by 


等 修饰 词 修饰 。 具 体 含义 留 给 读者 自己 动手 来 理解 。 
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例 24.6 ”使 用 条 件 判断 语句 选择 不 同 的 返回 信息 , 代码 如 下 : (实例 位 置 : 光盘 \TM\Instances\24\6) 


templates/6/index.tpl 文件 

<html > 

<head> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 

<title> {Stitle}</title> 

<link rel='stylesheet href="../css/style.css" /> 

</head> 

<body> 

<p> 

{if $smarty.get.type =—— ‘tm'} 

欢迎 光临 ，{$smarty.get.type} 

{else} 

对 不 起 ， 您 不 是 本 站 VIP， 无 权 访问 此 栏目 。 

区 

</body> 

</html> 

index.php 文件 

<?php 
include_once "../config.php"; 
Ssmarty->assign("title"," 让 条 件 判 断 语句 "): 
S$smarty->display("6/index.tpl"); 


?> 


运行 结果 如 图 24.8 所 示 。 


24.8 让 条 件 判断 语句 


2. foreach 循环 控制 

Smarty 模板 中 的 foreach 语句 可 以 循环 输出 数组 ， 与 另 一 个 循环 控制 语句 section 相 比 ， 在 使 用 格 
式 上 要 简单 得 多 ， 一 般 用 于 简单 数组 的 处 理 。foreach 语句 的 格式 如 下 : 

{foreach name=foreach _ name key=key item=item from=arr name} 

{/foreach} 

其 中 ，name 为 该 循环 的 名 称 ，key 为 当前 元 素 的 键 值 ，item 为 当前 元 素 的 变量 名 ;from 为 该 循环 
的 数组 。 其 中 ，item 和 from 是 必要 参数 ， 不 可 省 略 。 

例 24.7 使 用 foreach 语句 , 循环 输出 数组 infobook 的 全 部 内 容 , 代码 如 下 :实例 位 置 : 光盘 \TM\ 
Instances\24\7) 


templates/7/index.tpl 文件 
<html> 
<head> 
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<table width="100" border="0" align="left" cellpadding="0" cellspacing= "0"> 
{section name=secl loop=$obj} 
<t> 
<td colspan="2">{S$obi[secl].bigclass}</td> 
</t> 
{section name=sec2 loop=$obj[sec1].smallclass} 
<t> 
<td width="25">&nbsp:</td> 
<td width="75"> {$obj[sec1].smallclass[sec2].s type}</td> 
</t> 
{/section} 
{/section} 
</table> 
</body> 
</html> 
index.php 文件 
<?php 
Tequire "../config.php": 
$obj = array(array("id" => 1, "bigclass" => "计算 机 图 书 "."smallclass" => array(array("s_id" => 1, "s type" => 
"PHP"))),array("id" => 2, "bigclass" => "历史 传记 ","smallclass" => array(array("s_id" => 2, "s_type" => "中 国 历史 "), 
array("s_id" => 3,"s type”=> "世界 历史 "))).aray("id”=> 3,"bigclass”=> "畅销 小 说 ","smallclass"” => array 
(array("s_id" => 4,"s_type" => "网 络 小 说 "),array("s id" => 5, "s_type" => "科幻 小 说 ")))): 
$smarty->assign("title','section 循环 控制 小 
S$smarty->assign("obj", $0obj); 
S$smarty->display("8/index.tpl"): 


2> 


运行 结果 如 图 24.10 所 示 。 
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图 24.10 ”使 用 section 循环 控制 输出 数组 
24.3.6 ”内 建 函 数 


Smarty 自 带 一 些 内 建 函数 ， 内 建 函 数 是 模板 语言 的 一 部 分 ， 用 户 不 能 创建 名 称 与 内 建 函 数 相 同 的 
自 定义 函数 ， 也 不 能 修改 内 建 函 数 。 下 面 介绍 几 个 比较 常用 的 内 建 函 数 。 

1. config_load 函数 

从 配置 文件 中 加 载 变 量 。 配置 文件 有 可 能 包含 多 个 部 分 ， 此 时 可 以 使 用 附加 属性 section 指定 从 哪 
一 部 分 中 取得 变量 : 


{config load file="file name " section="add attribute"} 
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其 中 ,file_ name 指定 包含 的 配置 文件 的 名 称 ; add_attribute 为 附加 属性 ， 当 配置 文件 中 包含 多 个 部 
分 时 应 用 ， 指 定 具体 从 哪 一 部 分 中 取得 变量 。 

有 关 该 函数 的 应 用 可 以 参考 例 24.4。 

2. include 标签 

include 标签 用 于 在 当前 模板 中 包含 其 他 模板 ， 当 前 模板 中 的 变量 在 被 包含 的 模板 中 可 用 。 必 须 指 
定 file 属性 ， 该 属性 指明 模板 资源 的 位 置 。 标 签 语 法 如 下 : 


{include file="file name " assign=" " var=" "} 


其 中 ，file 指定 包含 模板 文件 的 名 称 ; assign 指定 一 个 变量 保存 包含 模板 的 输出 ; var 传递 给 待 包 
含 模板 的 本 地 参数 ， 只 在 待 包含 模板 中 有 效 。 

3. php 标签 

php 标签 允许 在 模板 中 直接 嵌入 PHP 脚本 。 是 否 处 理 这 些 语句 取决 于 $php_handling 的 设置 。 该 语 
句 通常 不 需要 使 用 ， 当 然 如 果 非 常 了 解 此 特性 或 认为 有 必要 ， 也 可 以 使 用 。 

php 标签 的 应 用 演示 如 下 : 


{php} 
Wincluding a php script directly 
// from the template. 
include("/conn.php"): 

{/php} 


上 述 代 码 为 直接 在 模板 中 应 用 include 语句 调用 包含 文件 。 
例 24.9 应 用 include 标签 在 模板 页 中 包含 其 他 模板 ， 并 通过 php 标签 在 模板 页 中 包含 其 他 PHP 
脚本 文件 。 实 例 代码 如 下 : 《实例 位 置 : 光盘 \TM\Instances\24\9) 


templates/9/index.tpl 文件 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<title> {Stitle}</title> 
<link rel="stylesheet" href="../css/style.css" /> 
</head> 
<body> 
<!-- 应 用 php 标签 通过 include 语句 调用 包含 文件 调用 --> 
{php} 
include("top.php"): 
{/php} 
<table width="99" border="0" cellpadding="0" cellspacing="0"> 
<t> 
<td height="20"><span class="STYLE1">{$arrl.object}</span></td> 
</b> 
<tr><td height="27"> 市 场 价 : {S$arrl.price} 王 </td></a> 
<tr><td height="22"> 热 卖 价 : {$arrl.t_price}¥¥</td></t> 
</table> 
<!-- 通 过 include 标签 包含 tpl 文件 --> 
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{include file="9/bottom.tp1"} 

index.php 文件 

<?php 
include '../config.php'; 
$arrl = array("object"=>' 液 晶 显示 器 '."price"=>'3500',"t_price"=>'2888"); 
$arr2 = array("object"=>' 羽 绒 服 ',"price"=>'150'."t_price"=>'88'); 
$arr3 = array("object"=>' 电 视 ',"price"=>'1000',"t_price"=>'888"); 
$smarty->assign("title', 应 用 内 建 函 数 "): 
$smarty->assign("arrl",Sarrl): 
$smarty->assign('arr2'.$arr2): 
$smarty->assign('arr3',$arr3); 
S$smarty->display('9/index.tpl"): 

?> 


在 本 实例 中 , 通过 php 标签 在 模板 页 中 直接 使 用 PHP 的 include 包含 语句 调用 头 文件 , 通过 Smarty 
的 include 标签 包含 tpl 文件 输出 页 面 的 尾 文 件 ， 运 行 结果 如 图 24.11 所 示 。 


图 24.11 php 标签 的 应 用 
24.4 ”Smarty 程序 设计 


镶 m 视频 讲解 ， 光盘 \TM\Video24\Smarty 程序 设计 .exe 

通过 前 面 的 学 习 已 经 知道 ， 在 Smarty 模板 中 ， 是 不 推荐 有 PHP 代码 段 的 ， 所 有 的 PHP 程序 都 要 
另 写成 文件 。Smarty 程序 的 功能 主要 分 两 种 : 一 种 功能 是 和 Smarty 模板 之 间 的 交互 ， 如 方法 assign、 
display; 另 一 种 功能 就 是 配置 Smarty， 如 变量 template_dir、$config dir 等 。 本 节 将 学 习 Smarty 程序 设 
计 的 其 他 一 些 方法 和 配置 参数 。 


24.4.1 Smarty 中 的 常用 方法 


1. assign 


assign 用 于 在 模板 被 执行 时 为 模板 变量 赋值 。 语 法 如 下 : 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


PHP 开发 实战 宝典 


“%%…%%index.tplphp” 格 式 的 文件 。 随 便 打开 一 个 这 样 的 文件 可 以 发 现 ， 实 际 上 Smarty 
将 模板 和 PHP 程序 又 重新 组 合成 一 个 混 编 页 面 。 

回 $cache dir: 缓存 目录 。 用 来 存放 缓存 文件 。 同样 , 在 cache 目录 下 可 以 看 到 生成 的 .html 文件 。 
如 果 caching 变量 开启 ， 那 么 Smarty 将 直接 从 这 里 读 取 文件 。 

回 $config dir 配置 目录 。 该 目录 用 来 存放 配置 文件 。 例 24.4 中 所 用 到 的 配置 文件 , 就 保存 到 这 里 。 

加 ”$debugging: 调试 变量 。 该 变量 可 以 打开 调试 控制 台 。 只 要 在 配置 文件 (config.php〉 中 将 
$smarty->debugging 设 为 tue 即 可 使 用 。 

加 ”$caching: 缓存 变量 。 该 变量 可 以 开启 缓存 。 只 要 当前 模板 文件 和 配置 文件 未 被 改动 ，Smarty 
就 直接 从 缓存 目录 中 读 取 缓 存 文件 而 不 重新 编译 模板 。 


24.5 实 战 
24.5.1 通过 Smarty 实现 网 页 的 动静 分 离 


铬 om 视频 讲解 ， 光 盘 \TMNVideo\24\ 通 过 Smarty 实现 网 页 的 动静 分 离 .exe 

Smarty 的 功能 是 实现 网 页 的 动静 分 离 ， 本 章 中 已 经 对 安装 、 配 置 和 使 用 Smarty 的 方法 进行 了 详细 
讲解 ， 下 面 将 应 用 Smarty 模板 技术 真正 实现 一 次 网 页 的 动静 分 离 。 

例 24.10 ”应 用 Smarty 模板 技术 ， 将 从 数据 库 中 读 取 的 数据 输出 到 网 页 中 。 操 作 步 又 如 下 : 〔 实 
例 位 置 ， 光盘 \TMNInstances\24\10) 

(1) 安装 和 配置 Smarty。 将 Smarty 模板 的 压缩 包 解 压 , 复制 libs 目录 到 服务 器 tmvsl\24\10\system 
目录 下 , 并 重新 命名 为 smarty, 在 smarty 目录 下 新 建 4 个 目录 templates、 templates_c、configs 和 cache， 
用 于 存储 不 同 的 文件 。 

编写 配置 文件 ， 分 别 指定 4 个 目录 的 存储 位 置 。 配 置 文件 system.smarty.inc.php 的 代码 如 下 。 
<?php 
require("smarty/smarty/libs/Smarty.class.php"): 
class SmartyProject extends Smarty{ 
function SmartyProjectO{ 
Sthis->template_dir ="./": // 指 定 模板 文件 存储 在 根 目录 下 
Sthis->compile dir="./system/smarty/templates c/": 
Sthis->config dir ="./system/smarty/configs/": 
Sthis->cache_dir = "./system/smarty/cache/":; 
} 


} 
?> 


(2) 创建 数据 库 操作 类 。 本 实例 中 通过 ADODB 来 操作 数据 库 ， 首 先 将 ADODB 包 放 置 在 tm\sl\ 
24\10\system 目录 下 。 然后 创建 数据 库 连 接 类 ， 将 其 存储 在 System.class.inc.php 文件 中 。 数 据 库 连 接 类 
的 代码 如 下 。 


class ConnDB{ /数据库 连接 类 
Var $dbtype: 


第 24 章 “Smarty 模板 技术 


Var $host: 
Var $user: 
Var S$pwd: 
Var $dbname: 
Var $debug: 
Var $conn; 
function ConnDB($dbtype.$hostSuser,$pwd.$dbname,Sdebug=false){ /构造 方法 
$this->dbtype=$dbtype: 
$this->host=$host: 
$this->user=$user: 
$this->pwd=$pwd: 
$this->dbname=$dbname: 
Sthis->debug=$debug; 
} 
function GetConnIdO{ // 实 现 数 据 库 的 连接 并 返回 连接 对 象 
require("adodb/adodb.inc.php"): 
这 $this->dbtype 一 "mysql" | $this->dbtype—"mssql"){ 
这 $this->dbtype 一 "mysql") 
$this->conn=NewADOConnection("mysql"): 
else 
$this->conn=NewADOConnection("mssql"): 
Sthis->conn->Connect($this->host. $this->user,$this->pwd.,$this->dbname):; 
}elseif($this->dbtype=—"access"){ 
Sthis->conn=NewADOConnection("access"); 
Sthis->conn->Connect("Driver={Microsoft Access Driver (*.mdb)};Dbq=".S$this->dbname."; Uid= 
".S$this->user.":Pwd=".$this->pwd.";"); 
} 
S$this->conn->Execute("set names gb2312"): 
这 $this->dbtype 一 "mysql") 
S$this->conn->debug=S$this->debug: 
Tetum $this->conn; 


} 
function CloseConnIdO){ // 关 闭 与 数据 库 的 连接 
$this->conn->DisconnectO: 
} 
} 


(3) 创建 system.inc.php 文件 ， 实 例 化 数据 库 连 接 类 ， 代 码 如 下 。 


<2?php 
require("system.smarty.inc.php"): 
require("system.class.inc.php"): 
// 数 据 库 连 接 类 实例 化 
$connobj=new ConnDB("mysql","localhost","root"."root","db_shop".false): 
$conn=$connobj->GetConnId(): 
// 调 用 Smarty 模板 
$smarty=new SmartyProjectO: 
?> 


(4) 创建 ndex.php 页 面 ， 定 义 主页 面 的 布局 ， 通 过 include 语句 调用 指定 的 包含 文件 ， 关 键 代码 
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如 下 。 


<t> 
<td width="286" height="514" rowspan="2" align="left" valign="top">&nbsp:</td> 
<td width="648" align= "center" valign="top"> 
<?php include(Cnominate php): ?> 
<td> 
<td width="70" rowspan="2" align="center" valign="top">&nbsp;</td> 
</t> 
<t> 
<td align="center" valign="top"> 
<?php include(‘newhot.php"): ?> 
<td> 
</t> 


(5) 创建 PHP 脚本 文件 nominate.php 和 newhot.php， 从 数据 库 中 读 取 数据 ， 并 将 数据 存储 到 模板 
变量 中 ， 最 后 指定 模板 页 面 。 这 里 只 给 出 nominate.php 文件 中 的 代码 。 
<?php 


require("system/system.inc.php"): // 调 用 指定 的 文件 
$sql = "select id.name.pics.m_price,v_price from tb_commo where isnom = 1 order by id desc": /定义 查询 语句 


Snum = 4: /定义 输出 记录 数量 
Srst = Sconn->SelectLimit($sql,$num); /执行 查询 语句 
S$nomarr = $rst->GetArray(); // 返 回 查 询 结果 


$smarty->assign(nomarr.$nomarr): 。“// 将 查询 结果 赋 给 一 个 数组 
S$smarty->display(nominate.tpl): /指定 模板 页 面 
> 
(6) 创建 pl 静态 页 面 nominate.tpl 和 newhot.tpl， 通 过 foreach 循环 读 取出 模板 变量 中 的 数据 ， 由 
于 篇 幅 所 限 ， 这 里 没有 给 出 tpl 文件 的 代码 ， 可 参考 光盘 中 的 内 容 。 
运行 结果 如 图 24.12 所 示 。 


的 物 邦人 


24.12 ”通过 Smarty 输出 数据 库 中 的 数据 
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24.5.2 ”Smarty 分 页 类 


铬 am 视频 讲解 :光盘 \TM\Video24\Smarty 分 页 类 .exe 

上 述 实 例 讲解 了 如 何 通 过 Smarty 实现 网 页 的 动静 分 离 ， 在 此 基础 上 讲解 如 何在 Smarty 中 实现 分 
页 功能 。 

例 24.11 应 用 Smarty 模板 技术 , 通过 分 页 类 将 从 数据 库 中 读 取 的 数据 分 页 输出 。 操 作 步 又 如 下 : 
(实例 位 置 ， 光盘 \TM\Instances\24\11) 

(1) 首先 进行 Smarty 的 安装 和 配置 。 这 里 不 再 赣 述 ， 具 体操 作 方 法 可 参考 24.2 节 中 的 内 容 。 

(2) 创建 数据 库 连 接 和 管理 类 。 这 里 不 但 编写 了 一 个 数据 库 连 接 类 ， 而 且 又 编写 了 一 个 数据 库 的 
管理 类 。 通 过 数据 库 管理 类 可 以 实现 对 数据 库 进行 查询 、 修 改 、 删 除 和 更 新 的 操作 ， 代 码 如 下 。 


class AdminDB{ /数据 库 管理 类 
function ExecSQL($sqlstr, $conn){ // 执 行 SQL 语句 
S$sqltype=strtolower(substr(trim($sqlstr).0.6)): // 截 取 SQL 语句 中 的 前 6 个 字符 串 
S$rs=$conn->Execute($sqlstr): 
if($sqltype—"select"){ // 判 断 如果 执 行 select 查询 
Sarray=$rs->GetRows(); // 返 回 查询 结果 
这 count($array) 一 0 || $rs 一 false) // 如 果 不 执行 查询 
Tetum false; // 返 回 false 
else 
Teturn $array; // 否 则 返回 一 个 数组 
jelseif ($sqltype—"update" || $sqltype—"insert" || $sqltype=—"delete"){ /如 果 执行 操作 语句 
这 Srs) 
retum true; 
else 
Tetum false; 


} 


数据 库 连 接 和 管理 类 的 完整 代码 存储 在 system.class.inc.php 文件 中 。 
(3) 创建 分 页 类 ， 同 样 将 其 存储 在 system.class.inc.php 文件 中 ， 分 页 类 的 代码 如 下 。 


class SepPage{ 
Var $Irs; 
Var $pagesize: 
Var $nowpage: 
Var $array: 
Var $conn:; 
Var $sqlstr: 
function ShowDate($sqlstr.Sconn.Spagesize.Snowpage){ // 构 造 方法 
这 !isset($nowpage) || Snowpage—"") /判断 变量 值 是 否 为 空 
S$this->nowpage=10: /定义 每 页 输出 的 记录 数 
else 
Sthis->nowpage=Snowpage: 
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Sthis->pagesize=$pagesize: /定义 每 页 输出 的 记录 数 
$this->conn=$conn: // 连 接 数据 库 返 回 的 标识 
Sthis->sqlstr=$sqlstr: // 执 行 的 查询 语句 
Sthis->rs=$this->conn->PageExecute($this->sqlstr, $this->pagesize, $this->nowpage); 
@S$this->array=$this->rs->GetRows(); // 获 取 记 录 数 
if(count($this->array)—0 || $this->rs—false) 
Tetum false; 
else 
Teturn S$this->array; 
} 
function ShowPage($contentname, Sutits,$anothersearchstr, $class){ 
$allrs=$this->conn->Execute($this->sqlstr): // 执 行 查询 语句 
Srecord=count($allrs->GetRows()): // 统 计 记 录 总 数 
S$pagecount=ceil($record/$this->pagesize): 1/ 计算 总 页 数 


S$str=" 共 有 ".$Scontentname."&nbsp:".$Srecord."&nbsp:".$utits."&nbsp: 每 页 显示 &nbsp:".$this->pagesize. "&znbsp:". 
Sutits."&nbsp: 第 &nbsp;".$this->rs->AbsolutePage()."&nbsp; 页 / 共 &nbsp:".$pagecount."&nbsp; 页 "; 
$str.="&nbsp:&nbsp:&nbsp:&nbsp:": 
if(!$this->rs->AtFirstPage()) 
$str.="<a href=".$_SERVER['PHP_SELF']."?page=1".$anothersearchstr." class=".$class."> 首 页 </a>"; 
else 
Sstr.="<font color=#555555'> 首 页 </font>"; 
$str.="&nbsp:": 
if(!$this->rs->AtFirstPage()) 
$str.="<a 
href=".$_SERVER[PHP_SELF']."?page=".($this->rs->AbsolutePage()-1).$anothersearchstr." class=".$class."> 上 一 页 </a>"; 
else 
S$str.="<font color=#555555'> 上 一 页 </font>"; 
$str.="&nbsp:"; 
if(!$this->rs->AtLastPage()) 
S$str.="<a 
href=".$_SERVER['PHP_SELF']."?page=".($this->rs->AbsolutePage()+1).$anothersearchstr." class=".$class."> 下 一 页 </a>"; 
else 
$str.="<font color=#555555'> 下 一 页 </font>"; 
Sstr.="&nbsp:"; 
if(!$this->rs->AtLastPage()) 
S$str.="<a href=".$_SERVER[PHP_SELF']."?page=".$pagecount.$anothersearchstr." class=".$class."> 尾 
页 </a>"; 
else 
$str.="<font color=-#555555> 尾 页 </font>": 
这 count($this->array) 一 0 || $this->rs—false) 
return "": 
else 
Tetum $str 


} 
(4) 创建 system.inc.php 文件 ， 对 数据 库 连 接 、 操 作 类 以 及 分 页 类 进行 实例 化 ， 代 码 如 下 。 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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Sarr = $rst->GetAssoc(); // 获 取 结 果 集 
$smarty->assign(arr.$arr): // 将 返回 的 结果 集 存储 到 指定 的 Smarty 模板 变量 中 
$smarty->display('public.tpl'): /执行 模板 文件 


> 


(3) 在 smarty\templates 文件 夹 下 创建 public.tpl 模板 文件 ， 输 出 模板 变量 中 的 公告 标题 信息 ， 关 
键 代码 如 下 。 


<td width="193" align="left" valign="top" class="exam"> 
{foreach key=key item=item from=$arr} 
<a href="#" class="Ik" onclick="retum showme({Skey},'showpub.php"):” ><img src="images/man.JPG" 
width="14" height="11" border="0" /> {Sitem}</a><br /> 
{/foreach} 
</td> 


(4) 创建 links.js 文件 ， 定 义 showme0 函 数 ， 通 过 JavaScript 脚本 调用 showpub.php 文件 ， 查 看 公 
告 的 详细 内 容 。showmeO 函 数 的 语法 如 下 : 


// JavaScript Document 

function showme(key,wurD){ 
Var purl = wurl + "?id="+key: 
open(purl，blank',width=450 height=200',false): 
return false; 


} 


该 函数 的 参数 是 指定 公告 信息 的 ID 和 调用 的 文件 。 
(5) 创建 showpub.php 文件 ， 根 据 传递 的 ID 值 ， 从 数据 库 中 查询 出 数据 的 详细 信息 ， 并 将 数据 
添加 到 指定 的 模板 变量 中 ， 最 后 指定 模板 页 。 


<?php 
include_once 'conn/conn.php': 
include_once 'config.php'; 
$id = $_GETT['id"]; 
$sql = "select * from tb_public where id =".$_GET['id']; 
Srst = $conn->execute($sql): 
$arr = $rst->getAssoc(): 
S$smarty->assign('title', 查 看 公告 ): 
$smarty->assign(arr.$arr[S$id]) 
S$smarty->display('showpub.tpl"); 
?> 


(6) 创建 模板 页 showpub.tpl， 读 取 模板 变量 中 的 数据 ， 输 出 公告 的 详细 内 容 ， 代 码 如 下 。 


<table width="400" align="center" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td width="70%" height="25" align="center" valign="middle" class="left"> 标 题 : {$arr.title}</td> 
<td width="30%" height="25" align="center" valign="middle" class="right">&nbsp:; {$arr.addtime}</td> 
</t> 
<tr> 
<td height="100" colspan="2" align="left"” valign="top" class="all” style=" text-indent: 10px:"><br>&nbsp: 
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{$arr.content}</td> 
</u> 
</table> 


运行 本 实例 ， 将 直接 输出 网 站 公告 的 标题 信息 ， 单 击 某 个 具体 的 标题 ， 将 弹出 一 个 新 的 窗口 ， 输 
出 具体 公告 的 内 容 ， 如 图 24.14 所 示 。 


ablic php =|Gjxl 
文件 因 ” 如 狠 四 查看 锌 。 收 章 凶 工具 四 帮助 区 3 
(7 ACHP EO SL. Wh... A 
她 直人 W | 物 http://127.0.0 1/tn/s1/24/12/public. php 司 BE 
本 tn //127. TEE x| = 
网 站 公告 
公告 信息 
口 欢迎 新 老 朋友 光临 标题 欢迎 新 老 朋 友 光 临 2008-04-23 
五 一 大 盖 宾 
口 节日 送 好 礼 热烈 欢迎 新 老 朋友 光临 。 本 公司 从 今日 起 开始 了 网 上 购物 业务 ， 希 望 
日 买 100 送 100 候 能 满意 
赔 : 


图 24.14 输出 公告 信息 
24.6 本 章 小 结 


本 章 主要 介绍 了 Smarty 模板 的 安装 、 配 置 及 使 用 ， 并 且 对 Smarty 的 模板 设计 和 程序 设计 进行 了 
讲解 ， 它 们 是 两 个 相辅相成 的 内 容 ， 是 应 用 Smarty 模板 的 基础 。 在 实战 中 讲解 了 Smarty 的 实际 应 用 。 
希望 通过 本 章 的 学 习 , 读者 能 够 掌握 Smarty 模板 技术 , 并 且 能 够 将 其 灵活 地 运用 到 实际 的 网 站 开发 中 。 


24.7 实战 练习 


1. 自 定 配置 一 个 Smarty 环境 , 并 将 Smarty 定 界 符 换 成 其 他 符号 。( 答 案 位 置 : 光盘 \TM\Instances\ 


24\13) 
2， 使 用 Smarty 模板 创建 一 个 购物 车 。 (答案 位 置 ， 光盘 \TM\Instances\24\14) 
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博客 管理 系统 

应 用 Smarty 模板 开发 电子 商务 平台 
办 公 自 动 化 系统 

供求 信息 网 

图 书 借阅 管理 系统 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


PHP 开发 实战 宝典 


25.1 项 目 描述 


博客 作为 Web 2.0 时 代 的 重要 应 用 之 一 ， 已 经 得 到 广泛 地 应 用 ， 所 以 Web 开发 人 员 应 该 掌握 博客 
的 基本 开发 流程 以 及 博客 中 各 个 模块 的 具体 功能 和 实现 方式 。 本 章 的 博客 主要 具有 发 表 、 查 询 、 删 除 
和 分 页 浏览 博客 文章 ， 发 表 、 删 除 文章 评论 ， 查 询 、 上 传 、 删 除 分 页 浏览 图 片 ， 添 加 、 查 询 、 删 除 、 
分 页 浏览 朋友 圈 ， 以 及 查询 、 浏 览 和 删除 用 户 信息 等 功能 。 

注册 为 正式 用 户 后 ， 即 可 发 表 博 客 文章 、 评 论 博客 文章 、 上 传 图 片 、 设 置 自己 的 朋友 圈 。 普 通用 
户 具 有 删除 自己 所 写 的 文章 和 上 传 的 图 片 的 权限 ， 网 站 管理 员 具 有 删除 普通 用 户 及 普通 用 户 所 发 表 的 
文章 和 上 传 的 照片 的 权限 。 博 客 管理 系统 的 首页 运行 效果 如 图 25.1 所 示 。 


图 25.1 博客 管理 系统 首页 运行 效果 


25.2 系统 分 析 


无 论 是 简单 的 桌面 应 用 还 是 复杂 的 电子 商务 网 站 ， 在 进行 项 目 开发 前 都 需要 花费 大 量 的 时 间 对 系 
统 各 个 方面 进行 分 析 ，“ 磨 刀 不 误 砍 柴 工 ”， 好 的 开头 才 是 整个 项 目 顺利 、 合 格 竣工 的 有 效 保障 。 


25.2.1 需求 分 析 


在 网 络 高 速 发 展 的 今天 ， 博 客 管理 系统 给 人 们 提供 了 打发 个 人 情感 、 人 与 人 之 间 进 行 良好 沟通 的 
平台 。 博 客 拥有 真实 的 内 容 ， 人 们 可 以 通过 博客 记录 工作 、 学 习 、 生 活 和 娱乐 的 点 滴 ， 以 及 发 表 文章 
和 对 事物 的 评论 ， 从 而 在 网 上 建立 一 个 完全 属于 自己 的 天 地 ， 博 客 已 成 为 当今 网 络 最 为 个 性 化 和 平民 
化 的 个 人 展示 的 空间 和 平台 。 对 于 网 民 ， 只 要 拥有 博客 ， 就 可 以 超越 现实 生活 ， 拥 有 不 同 以 往 的 全 新 
网 上 生活 ， 对 于 博客 服务 商 ， 则 必须 从 功能 提供 转型 到 全 方位 社会 服务 的 提供 ， 建 立 虚 拟 社会 ， 并 负 
责 其 维护 ， 保 证 博客 日 常 运行 ， 对 于 社会 而 言 ， 有 利于 构建 和 谐 的 互联 网 空间 ， 维 护 和 谐 的 社会 环境 。 
从 这 个 角度 来 说 ， 构 建新 生活 方式 ， 将 是 互联 网 发 展 的 一 个 里 程 碑 。 很 多 门户 网 站 都 为 注册 用 户 提供 
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了 免费 的 个 人 博客 空间 ， 也 因此 吸引 了 很 多 用 户 注 册 ， 从 而 很 大 程度 上 提高 了 网 站 的 访问 量 和 知名 度 ， 
所 以 在 开发 社区 性 、 娱 乐 性 等 网 站 中 ， 提 供 博客 模块 是 很 有 必要 的 。 


25.2.2 系统 目标 


根据 网 站 性 质 和 需求 ， 网 站 所 包含 的 功能 也 是 不 同 的 ， 所 以 在 项 目 开发 前 一 定 要 认真 做 好 需求 分 
析 ， 掌 握 用 户 所 需 和 项 目 目标 。 本 博客 系统 主要 实现 如 下 目标 : 
系统 采用 B/S 架构 ， 实 现 人 机 交互 。 
系统 运行 稳定 ， 安 全 可 靠 。 
系统 界面 设计 美观 友好 ， 操 作 简 便 。 
突出 重点 内 容 ， 显 示 最 新 文章 和 图 片 等 信息 。 
非 登录 用 户 可 以 浏览 文章 、 浏 览 图 片 、 发 表 评 论 ， 登 录用 户 可 以 管理 自己 的 文章 和 上 传 的 图 
片 等 信息 。 
全 面 的 搜索 查询 功能 ， 包 括 精确 查询 和 模糊 查询 。 
完善 的 文章 管理 功能 ， 包 括 文章 的 发 表 、 删 除 ， 及 对 文章 的 评论 与 回复 。 
支持 图 片上 传 功能 。 
支持 好 友 功 能 。 
支持 公告 栏 功 能 。 


回 轿 图 罗 加 


回 罗 图 罗 加 


25.2.3 ”系统 功能 结构 


本 系统 的 项 目 描述 中 已 经 详细 介绍 了 该 博客 所 具有 的 主要 功能 ， 为 了 使 读者 更 加 直观 和 理性 地 了 
解 该 博客 系统 所 具有 的 功能 ， 下 面 以 结构 图 的 形式 进行 展示 ， 如 图 25.2 所 示 。 


博客 系统 
y 
用 户 注册 
用 户 登录 
普通 用 户 超级 用 户 


文章 管理 图 片 管理 [朋友 加 管理 ] 户 管理 
I [ ] I TF 
添 || 吉 LE 

如 | 河 | | 于 | 测 | 可 | | 当当 | 瘟 | 归 IE | 
二 | 二 | “| 如 | 各 || 交 | | 到 || 我 || 盟 | | 朋 四 用 || 用 | 用 
守 || 客 | ”| 图 || 一 | 图 | | 表 || 的 || 友 | | 去 上 中 || 忆 | 已 
时 | 国 国 加 加 | 国 加 国 卫 蜡 信 信 上 | 信 || 信 
章 || 章 友 || 息 | | 和 息 息 || 息 || 息 


25.2 博客 管理 系统 的 功能 结构 图 
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25.2.4 ”系统 流程 图 


完成 系统 的 基本 需求 和 功能 分 析 后 ， 即 可 规划 出 博客 所 具备 的 功能 和 操作 流程 。 本 博客 系统 的 流 
程 图 如 图 25.3 所 示 。 


EE 


图 25.3 博客 管理 系统 流程 图 


25.3 ”软件 开发 环境 


项 目 能 够 顺利 竣工 ， 好 的 开发 环境 和 开发 工具 也 是 必要 的 。 在 开发 博客 管理 系统 平台 时 ， 该 项 目 
使 用 的 软件 开发 环境 如 下 。 

回 “服务 器 端 
操作 系统 : Windows Server 2003 。 
服务 器 : Apache 2.0。 
PHP 软件 : PHP 5.0。 
数据 库 : MySQL 5.0。 
MySQL 图 形 化 管理 软件 : phpMyAdmin-2.9.0.2。 
开发 工具 : Dreamweaver 8 和 Zend Studio for Eclipse。 
浏览 器 : IE 6.0。 
分 辩 率 : 最 佳 效果 1024X768 像素 。 


VvvyvyY 


vv 


v 
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回 ”客户 端 


> 浏览 器 : 推荐 使 用 正 6.0 及 以 上 版 本 。 
> “分 辩 率 : 最 佳 效 果 1024X768 像素 。 


25.4 数据 库 与 数据 表 的 设计 


目前 ， 数 据 库 是 程序 开发 中 大 量 数据 有 效 存储 的 最 佳 载体 ， 任 何 计算 机 语言 都 有 与 之 结合 性 最 好 
的 数据 库 系 统 。PHP 一 般 与 MySQL 数据 库 组 合 开发 ， 所 以 本 博客 系统 也 将 采用 MySQL 作为 后 台数 据 
库 。 下 面具 体 讲解 本 系统 中 数据 库 及 数据 表 的 设计 过 程 。 


25.4.1 数据 库 分 析 


PHP 可 以 支持 多 种 数据 库 ， 如 Oracle、Sybase、SQL Server、mSQL、MySQL 等 。 在 这 些 数据 库 
中 ， 由 于 MySQL 具有 免费 、 跨 平台 、 使 用 方便 、 访 问 效率 较 高 等 特点 ， 所 以 得 到 广泛 地 应 用 ， 是 业界 
公认 的 PHP 的 “黄金 搭档 ”，Linux 系统 、Apache 服务 器 、MySQL 数据 库 和 PHP 语言 构成 了 现在 主流 
的 LAMP 网 站 架构 模式 。 综 上 原因 ， 本 博客 系统 也 将 使 用 MySQL 作为 博客 系统 中 数据 存储 的 载体 。 


25.4.2 数据库 E-R 图 设计 


根据 需求 分 析 和 功能 设计 ， 本 系统 拟订 了 用 户 实体 、 上 传 图 片 实体 、 朋 友 圈 实体 、 文 章 实体 以 及 
留言 实体 。 为 了 使 读者 更 清晰 地 了 解 每 个 实体 所 具备 的 功能 ， 下 面 给 出 系统 中 主要 实体 的 E-R 模型 。 

用 户 是 博客 活动 的 主要 参与 者 ， 必 须 对 用 户 身份 进行 收集 ， 所 以 将 用 户 个 人 信息 抽象 为 用 户 实体 
表示 。 用 户 实体 包括 注册 用 户 的 详细 信息 ， 如 果 想 在 本 博客 系统 中 进行 发 表 文 章 、 上 传 图 片 等 操作 ， 
则 必须 要 先进 行 注册 。 用 户 信息 实体 E-R 图 如 图 25.4 所 示 。 

博客 可 以 保存 用 户 上 传 的 图 片 、 照 片 等 内 容 ， 为 了 有 效 地 保存 这 些 内 容 ， 可 以 将 图 片 抽象 为 图 片 
实体 。 图 片 实体 主要 包括 上 传 图 片 的 名 称 、 上 传 图 片 的 用 户 和 上 传 图 片 时 间 等 ， 图 片 实体 E-R 图 如 
图 25.5 所 示 。 


上 传 时 间 
图 片 空间 


25.4 用 户 实体 E-R 25.5 ”图 片 实体 ER 图 
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25.4.3 ”创建 数据 库 和 数据 表 


完成 对 博客 实体 分 析 后 ， 下 面 根据 分 析 结 果 创 建 数据 库 和 数据 表 。 创 建 和 维护 MySQL 数据 库 及 
数据 表 ， 既 可 以 在 Windows 系统 的 命令 提示 符 窗口 或 Linux/UNIX 系统 的 终端 命令 窗口 中 实现 ， 也 可 
以 使 用 MySQL 的 图 形 化 界面 管理 工具 实现 。MySQL 图 形 界面 管理 工具 有 多 种 ， 其 中 ，phpMyAdmin 
是 由 PHP 编写 的 通过 客户 端 浏览 器 对 MySQL 数据 库 进行 管理 的 工具 ， 其 完全 免费 、 安 装 方便 ， 所 以 
本 系统 将 使 用 phpMyAdmin 作为 MySQL 数据 库 创 建 和 维护 的 工具 。 

在 浏览 器 中 打开 phpMyAdmin， 如 图 25.6 所 示 ， 在 “创建 一 个 新 的 数据 库 ” 选 项 组 中 的 文本 框 中 
输入 “db _database25” 作 为 博客 数据 库 的 名 称 ， 然 后 单 击 “ 创 建 ” 按 钮 即 可 完成 数据 库 的 创建 。 

完成 数据 库 的 创建 后 ， 即 可 创建 博客 所 要 使 用 的 数据 表 。 根 据 实 体 E-R 图 和 本 系统 的 实际 情况 ， 
需要 创建 6 张 数据 表 ， 其 中 db_database25 数据 库 中 所 包含 的 表 如 图 25.7 所 示 。 


a 
办 和 和 总 埋 
Be 
Dead 
D5 

四 "| 


图 25.6 创建 数据 库 


下 面具 体 介绍 这 6 张 数据 表 的 结构 设计 和 说 明 。 
回 tb_article (文章 表 ) 
文章 表 用 于 存储 用 户 发 表 过 的 文章 信息 。tb_article 表 的 结构 如 图 25.8 所 示 。 


缠 服务 器 ;localhost ， 郧 歼 据 库 ; db_database25 服务 器 :localhost ， 国 数据 库 : db_database25 ， 国 表 :tb article 

I fen. Pa Ee 人 EN A 刘 览 。 队 装 构 ,RSsol 矿 搜 示 了 轿 入 虹 导出 _ 孙 Import 狐 挫 作 ”[ 嘿 洁 空 。 风 遇险 
lp xn EE 大 小 地 二 
< nl 0622ehinesse Sm FR 美 型 整理 尾 性 Nul Bi 机 外 
2 WBA on2H2chinesed 21m 厂 a inX10) 否 auto_incremert 
5 WOW 79M2chnese- 6 2.4m FF ontert medurtad 的 3912_thinese il 再 
加 WM ER [SE 厂 aathor varchari20) ob2312_chinese_ci 否 
和 | HE FT mw dateime 和 理 。 0000-00-00 000000 
3 WA oH2ehinesed 252m 

7 | 坊 入 人 04 二 75 旭日 字 厂 tile varchan200) gb2312_chinese_cl 否 
图 25.7 db _database25 数据 库 所 包含 的 数据 表 图 25.8 文章 表 结构 


回 ”也 包 ecomment (评论 表 ) 
评论 表 存 储 的 是 用 户 对 文章 的 评论 , 注册 用 户 和 游客 都 可 以 发 表 评 论 。tb_filecomment 表 的 结构 如 
图 25.9 所 示 。 
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回 也 _fiend〈( 好 友信 息 表 
ee 性 别 、 生 日 等 好 友 的 个 人 信息 。tb_friend 表 的 结构 如 图 25.10 所 示 。 


因 服务器 -localhost 局 数据 库 : db_database25 ， 下 表 :tb_friend 
轩 尖 曲 疝 区 哲 ,msol 户 执 过 基 狐 入 [ 尖 寻 由 膨 wpor 禾 扣 作 硬 清 字 内 内 


字 县 a 斐 悍 虹 性 Nm 点 认 额外 
厂 显 ms) 村 aut_nerament 险 
厂 mame Verchat(s0) W231 ennese_ rl 要 匡 
国 服务器 :1ocalhost ， 局 数据 库 : db_database25 ， 加 表 :tb_filecomment | we 刺 二 RS 可 渤 国 
E F 昨 da 要 conn0no0 区 
| 后 浏 贤 时 寺 构 “天 sa 万 排 过 了: 医 入 入 呈 出 及 mpor 黎 据 村 出 砍 空 河 弄 除 下 | 向 [El 理 站 
厂 adhess 。 varcharl0g oh2312 chinese_ sl 要 区 
二 一 RE RN A RW NT FT peacede。 verha sb2at2_omese il。 村 医 
= em rcharen) kazehineoe tl 克 
FF mea rudy 了 F he) haehinesesl 要 日 
厂 username varchar(2n) gb2312_thinase_oi 理 厂 andes verchara0) W2312 ehnose el 再 隆 
厂 contert -ted 92312_thinase_ol 否 Fo achanG0) 2311_eninese sl 本 卓 
[datetime datetime 否 。 o00c0000000000 samame vonarco gp292ennoset 再 加 


图 25.9 评论 表 结 构 图 25.10 好 友信 息 表 结构 


回 tb public (公告 栏 信 息 表 ) 

公告 栏 信 息 表 主要 记录 了 网 站 情况 、 博 客 系统 的 版 本 情况 或 网 站 活动 等 内 容 。 公 告 栏 信息 表 的 结 
构 如 图 25.11 所 示 。 

加 ”tb_tpse〈 图 片 信 息 表 ) 

图 片 信息 表 存储 的 是 上 传 图 片 的 信息 ， 如 图 片 名 称 、 上 传 用 户 、 上 传 时间 等 。tb_tpsc 表 的 结构 如 
图 25.12 所 示 。 


园 服务 器 :localhost } 克 数据 库 : db_database25 ， 回 表 :tb_public 加 民 务 器:1ocalhost ， 加 数据库 db_dntabase25 ， 回 家 ;tb_tpso 
| 加 S08 本 二 机 吉 SQL 上 瑰丽 A 及 号 出 随 wnpor 天 呈 人 全 寺 至， 区 EL 二 要 过 于: 搬入 虽 mpon 能 所 作者 请 安 淹 出 险 
FR Ru 属性 Nul 黑人 国外 

an ER 和 Ta 要 aaounement 图 .| 
厂 上 的 有史 厂 tpme were) oh2312_qhnese_ql 机 图 史 
te vanhar50) 。 92912_chness_sl 再 加 贿 X ge hao Buy 可 图 几 
厂 centent varchar(200) gb2312_chinese_cl 杰 国人 PX = ER ey RO 3 间 少 | 
pub_lime date 理 国 沪 xX ee 百 。 topooon 则 7 


图 25.11 公告 栏 信息 表 结构 图 25.12 图 片 信息 表 结 构 


加 ”tb_user( 用 户 信息 表 ) 
用 户 信 息 表 主要 存储 用 户 的 个 人 信息 。tb_user 表 的 结构 如 图 25.13 所 示 。 


同 服 务 器 .localhost + 吕 数据 库 : db_database25 ， 回 入 :tb_user 
| 四 ms 而 扫 和 8soL 广 可 站 美和 卫 出 旦 mpor 履 革 作 痢 过 和 
4 su 可 各 压 桂 Mul Ri 可 外 

ru mk2D EE auto_neamant 咀 
eoname veheon) go2312rnnesa dl 要 时 
eeaname vacha0) oy2512chinese.d 否 时 
Fapwd varcharls0) 了 2312_rhinese_i 枉 加 
regbrthday dato 委 0000.00.00 国 
TT eeemal -varchardo0) Do231?_eminesa dl 要 时 
regcity varchartt00) 的 2312_thinese ci 加 3 
F aas varehats0) 02312_shinesa_ci 本 加 
FE ease eh) piesaa 天 习 
eo varcharte0) gu2312_chinesa_ci 理 
三 reghomepage varcha(100) go2312 chiness ci 于 加 
regsign vareha00) 和 2312_rhinesa_ci 理 加 
maoaee moetad W014 rnt dl 于 时 
Fe hdd gar2 ennesed 要 习 
Te i) a 四 


25.13 用户 信息 表 结 构 
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25.5 首页 设计 


首页 是 整个 博客 的 入 口 地 址 ， 合 理 的 首页 布局 和 模块 分 配 直接 影响 到 用 户 对 博客 的 第 一 印象 。 为 
了 吸引 更 多 的 用 户 浏览 和 使 用 博客 ， 在 开发 项 目 时 需要 精心 地 对 首页 进行 设计 。 


25.5.1 首页 概述 


本 博客 系统 在 页 面 设计 上 采用 传统 的 排版 方式 ， 主 要 由 首部 导航 栏 、 左 侧 显示 区 和 主 显示 区 3 部 


分 组 成 ， 如 图 25.14 所 示 。 
回 ”首部 导航 栏 : 包括 导航 链接 、 用 户 登录 等 模块 。 
回 左 侧 显 示 区 : 包括 最 新 文章 、 最 新 图 片 和 系统 时 间 等 模块 。 
加 ” 主 显示 区 : 为 系统 公告 栏 ， 显 示 系 统 及 网 站 的 最 新 咨询 等 信息 。 


| SD 江上 人 Rog 二 


图 25.14 博客 系统 首页 结构 
25.5.2 首页 技术 分 析 


本 博客 首页 的 主 显 示 区 是 一 个 可 以 自 下 而 上 移动 的 公告 栏 。 公 告 栏 主要 用 于 公布 系统 版 本 的 更 新 
或 升级 信息 、 网 站 的 最 新 活动 安排 等 内 容 ， 也 可 以 链接 一 些 用 户 的 精彩 文章 。 本 系统 的 公告 栏 可 以 上 
下 移动 ， 主 要 是 应 用 HTML 语言 的 <marquee> 标 记 实 现 。 使 用 <marquee> 标 签 可 以 实现 文字 或 图 片 的 滚 
动 效果 ， 增 强 了 实用 性 的 同时 ， 也 增强 了 观赏 性 。 下 面 将 介绍 这 个 标签 的 常用 属性 和 方法 。 

1. <marquee> 标 签 的 文字 移动 属性 

<marquee> 标 签 的 特点 就 是 可 以 使 文字 或 图 片上 下 移动 。 早 期 , 这 是 一 个 了 不 起 的 技术 , 随 着 W3C 
标准 的 逐渐 完善 ，<marquee> 标 签 已 经 少 有 用 武之 地 了 。 但 有 些 技术 是 永远 不 变 的 ， 如 对 于 <marquee> 
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而 判断 用 户 所 输入 的 验证 码 是 否 正确 ， 代 码 如 下 。 


<?php 

$str=array(" 大 "," 更 "," 创 "," 天 "," 科 "," 客 "," 博 "," 技 "," 立 "," 新 "); // 汉 字数 组 

$word=strlen($str): 

for(Si=0:8i<4:8iH+){ 
Snum=rand(0,$word*2-1): // 随 机 获取 汉字 数组 的 键 值 
Simg=$img."<img src= images/checkcode/". $num.".gif width="16' height="16>"; /显示 随机 图 片 
Spic=$pic.$str[Snum]: // 将 图 片 转换 成 数组 中 的 文字 

人 


25.5.3 ”首页 的 实现 过 程 


铬 m 视频 讲解 : 光盘 \TMNVideov2s\ 首 页 的 实现 过 程 .exe 
(1) 使 用 session_startO 函 数 启用 Session 支持 ， 并 使 用 include 语句 包含 数据 库 连 接 文件 ， 从 而 在 


首页 中 导入 与 数据 库 的 连接 代码 。 


<?php 

session start(); // 开 启 Session 功能 
include "Conn/conn.php": // 包 含 数据 库 连 接 文件 
Ke 


(2) 建立 用 户 登 录 表 单 ， 用 于 录入 用 户 的 登录 信息 ， 表 单 及 表单 结构 如 表 25.3 所 示 。 
表 25.3 表单 及 表单 元 素 


name="txt_ pwd" type="password" style="FONT-SIZE: 9pt; WIDTH: 
65px" size="6" 


name="txt_yan" style="FONT-SIZE: 9pt WIDTH: 65px" size="8" 
type="hidden" name="txt_hyan" id="txt_hyan" value="<?php echo 
Spic;?>" 
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style="FONT-SIZE: 9pt” type="submit" value= "登录 " name="sub_ dl" 
onClick="returm f check(form)” 


(3) 在 左 侧 显 示 区 内 显示 最 新 的 5 篇 文章 的 主题 ， 代 码 如 下 。 


<?php 
$sql=mysql_query("select id.title from tb_article order by now desc limit 5"); /查询 最 新 5 篇 文章 
$i=1; 
while($info=mysql_fetch_array($sq])) // 循 环 显示 文章 主题 
{ 


<t> 
<td width="201” align="left" valign="top">&nbsp:&nbsp:&nbsp:<a href="article.php?file id=<?php echo 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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$sql=mysql query("select * from tb_user Where Tegname ='$UserName"™); 
Sresult=mysql fetch array($sq)); 


if ($result!=false){ // 如 果 用 户 名 已 经 被 注册 则 给 出 提示 
echo ("<script>alert( 用 户 名 已 被 注册 ! "):history.go(-1):</script>"); 
exit(); 


} 

$_SESSION[username]=$_POSTI[txt_regname]:; /将 用 户 名 保存 到 Session 中 
$regname=$_ POST[txt_ regname]: /接收 表单 内 容 
$regrealname=$_ POST[txt regrealname]: 

S$regpwd=mds($_ POST[txt_ regpwd]): 
Sregbirthday=$_POST[txt_birthday]: 

Sregemail=$_ POST[txt regemail]: 

Sregcity=$_POST[txt_province].$_ POST[txt_city]: 

$regico=$_ POST[txt ico]: 

$regsex=$_POST[txt_regsex]: 

Sregqq=$_POST[txt_regqq]; 
$reghomepage=$_POST[txt_reghomepage]: 

Sregsign=$ POSTI[txt_regsign]; 
Sregintroduce=$_POST[txt_regintroduce]; 
Sip=getenv(REMOTE_ADDR): /获取 用 户 正 


SINS=mysql_query("Insert Into tb_user (regname, regrealname, regpwd, regbirthday, regemail, regcity, regico, regsex, 
regqq, reghomepage, regsign, regintroduce, ip, fig) Values (‘$regname', '$regrealname', '$regpwd', '$regbirthday", 


'$regemail', '$regcity', '$regico', '$regsex', '$regqq', 'Sreghomepage', '$regsign', '$regintroduce', '$ip', 0)"): 


echo "<script> alert( 用 户 注册 成 功 ! "):</script>":; // 提 示 用 户 注 册 成 功 
echo "<script> window.location='file.php':</script>"; /重新 定位 到 file.php 页 面 
?> 


25.6.3 用 户 登录 


使 m 视频 讲解 ， 光盘 \TMNVideov2s\ 用 户 登录 .exe 


如 果 用 户 已 经 注册 为 本 博客 的 会 员 ， 那 么 在 发 表 文 章 或 上 传 图 片 时 需要 进行 登录 。 本 博客 的 登录 
页 面 如 图 25.16 所 示 。 


图 25.16 用户 登录 页 面 


在 介绍 首页 的 实现 过 程 时 ， 已 经 详细 介绍 了 用 户 登 录 表 单 及 表单 元 素 ， 这 里 不 


再 


痪 述 。 当 用 户 填 


写 完 个 人 信息 后 ， 单 击 “登录 ”按钮 即 可 将 用 户 录入 的 表单 信息 提交 到 chkuserphp 页 面 ， 该 页 面 用 于 


对 用 户 的 登录 信息 进行 验证 ， 代 码 如 下 。 
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JavaScript 在 前 台 对 用 户 所 输入 的 内 容 进行 验证 ， 代 码 如 下 。 


<script laneuage="javascript"> 
function check(form){ // 定 义 check0 函 数 
if (document.myform.sel key.value—""){ // 济 断 关键 字 是 否 为 空 
alert(" 请 输入 查询 条 件 !"):myform.sel key.focusO:retum false: 
} 
} 
</script> 


(3) 用 户 正 确 填 写 查询 表单 中 的 内 容 并 单 击 “ 提 交 ” 按 钮 后 ， 查 询 信息 将 被 提交 到 当前 页 进行 处 
理 ， 并 将 查询 结果 显示 在 当前 页 ， 代 码 如 下 。 


<?php 
这 (isset($_ POST[sel key]){ // 判 断 是 否 单 击 “ 提 交 ” 按 钮 
$tj=$_POST[sel tj]: // 接 收 提交 的 查询 信息 


$key=$_POST[sel key]: 
$sql=mysql_query("select * from tb_user where Stj='Skey"): 。“// 查 询 用 户 信息 
S$result=mysql_fetch_array($sql): // 获 取 查询 结果 集 
if($result=—false){ 
echo ("[<font color=red>Sorry! 该 用 户 不 存在 !</font>]"); 
} else{ 
Ep 
<!-- 省 略 了 部 分 代码 --> 
<?php 
} 
} // 查 询 模 块 结束 


?> 
进入 用 户 信息 查询 模块 ， 首 先 选择 查询 条 件 并 在 “关键 字 ” 文 本 框 中 输入 要 查询 的 关键 字 ， 然 后 


单 击 “检索 ”按钮 将 显示 出 查询 结果 。 例 如 ， 查 询 条 件 选择 “用 户 名 ”， 关 键 字 输入 “Tsoft”， 然 后 
单 击 “检索 ”按钮 ， 将 在 页 面 中 显示 名 为 Tsoft 的 用 户 信 息 ， 如 图 25.17 所 示 。 


要 9 件 : 网 FS 相 天 炬 于 soft a 


用 户 管 


RFD 3 BW so nes a 让 玉昌 


出 生 晶 由 ”1990-01-01 
所 下 同市 吉 F 长 夺 
个 人 主页 

个 性 从 名 

Ei 有 


25.17 查询 用 户 信息 
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<td align="right" bgcolor="#E9EAES" class="hongse01"> 


<?php 
if($page!=D){ 
echo "<a href=browseuser.php?page=1> 首 页 </a>&nbsp:": 
echo "<a href=browseuser.php?page=".($page-1)."> 上 一 页 </a>&nbsp:"; 
} 
这 $page<$page_counb) 
{ 
echo "<a href=browseuser.php?page=".($page+1)."> 下 一 页 </a>&nbsp:"; 
echo "<a href=browseuser.php?page=".$Spage_count."> 尾 页 </a>"; 
} 
} 
} 
?> 


进入 用 户 信息 浏览 模块 ， 如 图 25.18 所 示 ， 用 户 可 以 通过 单 击 分 页 链接 实现 用 户 信息 的 分 页 显示 。 
如 果 是 管理 员 登 录 ， 还 可 以 删除 指定 的 用 户 信息 。 


图 25.18 浏览 用 户 信息 


25.7 文章 管理 模块 设计 
文章 管理 模块 是 博客 系统 中 较为 重要 的 模块 之 一 ， 因 为 博客 的 一 个 核心 功能 就 是 为 用 户 提供 发 表 
自己 的 文章 的 功能 。 所 以 ， 对 博客 的 文章 管理 模块 进行 精心 设计 是 必要 的 。 
25.7.1 文章 管理 模块 概述 
本 系统 的 文章 管理 模块 包括 “发 表 文章 ”、“ 查 看 文章 ”、“ 其 他 用 户 文章 ”、“ 发 表 评 论 ”、 


“删除 文章 ”和 “删除 评论 ”6 项 功能 。 其 中 ， 普 通用 户 只 能 删除 自己 的 文章 及 对 文章 进行 评论 ， 只 有 
管理 员 才 有 权 删 除 任何 一 篇 文章 及 回复 。 文 章 管理 模块 的 框架 如 图 25.19 所 示 。 
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管理 员 权限 ” 一 一 一 普通 用 户 权限 
图 25.19 文章 管理 模块 框架 图 


25.7.2 ”文章 管理 模块 技术 分 析 


铬 ml 视频 讲解 ， 光 盘 \TM\Video\25\ 文 章 管理 模块 分 析 .exe 

大 多 数 情况 下 ， 只 有 用 户 成 功 登 录 后 才 可 以 在 论坛 或 博客 中 发 表 帖 子 或 文章 ， 这 样 用 户 可 以 有 效 
地 管理 自己 所 发 布 的 内 容 , 而 且 可 以 定位 不 同文 章 的 作者 。25.7.1 节 中 已 经 介绍 了 不 同 用 户 具有 不 同 的 
权限 ， 那 么 如 何 为 用 户 分 配 权限 呢 ? 有 Web 编程 基础 的 读者 都 知道 通过 Session 可 以 跟踪 和 定位 访问 
Web 服务 器 的 不 同 用 户 ， 同 样 ，PHP 也 可 以 采用 Session 来 保存 用 户 的 身份 信息 ， 在 进行 站 内 活动 时 ， 
根据 Session 所 保存 的 用 户 身份 信息 来 判断 用 户 是 否 具 备 某 项 操作 的 权限 。 

Session 的 中 文 含义 是 “会 话 ”， 是 指 用 户 从 进入 网 站 开始 ， 直 到 关闭 网 站 这 段 时 间 内 ， 所 有 网 页 
共同 使 用 的 公共 变量 的 存储 机 制 。Session 比 Cookie 更 有 优势 : Session 是 存储 在 服务 器 端的 ， 不 易 被 
伪造 ,Session 的 存储 没有 长 度 限制 ，Session 的 控制 更 容易 、 更 安全 。 

程序 开发 人 员 要 在 程序 编写 过 程 中 灵活 运用 Session， 首 先 应 该 掌握 Session 的 相关 配置 ，PHP 中 
对 Session 进行 配置 是 在 php.ini 文件 中 进行 的 。 表 25.7 为 PHP 中 Session 的 相关 配置 。 

表 25.7 ”Session 的 常用 配置 选项 


配置 选项 说 明 
Session.SaVe_path 三 cx 保存 Session 变量 的 目录 ， 在 Linux/UNIX 下 为 /tmp 
SessionUes_cookies 三 1 是 否 使 用 Cookie 
session.name = PHPSESSID 表示 会 话 D 


session.auto_start = 0 
session.cookie lifetime =0 


是 否 自 动 启用 Session， 当 为 1 时 ， 在 每 页 中 不 必 调 用 Session_satrt0 函 数 
设 定 Cookie 送 到 浏览 器 后 的 保存 时 间 ， 单 位 为 秒 。 默 认 值 为 0， 表 示 直 到 浏览 器 关闭 


session.cookie path=/ 


session.cookie domain 三 
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尽 可 能 的 将 session_start0 函 数 放 到 第 一 行 。 
25.7.3 ”添加 文章 的 实现 过 程 
铬 im 视频 讲解 ， 光盘 \TMNVideov2S\ 添 加 文章 实现 过 程 .exe 


用 户 成 功 登录 博客 后 ， 会 自动 跳 转 到 添加 文章 页 面 ， 当 然 也 可 以 通过 单 击 “文章 管理 ”/“ 添 加 博 
客 文 章 ” 超 链接 返回 到 添加 文章 页 面 。 文 章 添加 页 面 的 运行 结果 如 图 25.20 所 示 。 


Nas 
pe 


Seez， Bz) mrs Pr re Fa ne os) 


习 


wey 


[oe em 


图 25.20 添加 文章 页 面 的 运行 结果 
添加 文章 页 面 所 涉及 的 表单 及 表单 元 素 如 表 25.9 所 示 。 
表 25.9 添加 文章 页 面 中 的 表单 及 表单 元 素 


元 素 类 型 | 元素 名 称 属性 设置 含义 

回 fom myform method="post" action="check_file.php" 添加 文章 表单 

[text txt title id="txt_title" size="68" 文章 标题 
name="font" class="wenbenkuang" id="font" onChange="showfont 

贺 select font 人 文章 字体 
(this.options[this.selectedIndex].value)” 
class="wenbenkuang" onChange= "showsize(this.options[this. 

El select size 有 ES ie pen 字体 大 小 
selectedIndex].value)” 
nChange="showcolor(this.options[this.selectedIndex].value)" 

国 select color 上 二 pi - 辣 字体 颜色 
name="color" size="1" class="wenbenkuang" id="select" 

匹 ] textarea file Cols="75" rows="20" id="file" style="border:0px:width:520px:" 文章 内 容 

DD) submit bn tj id="btn_tj" value=" 提 交 " onClick="return checkO:" 提交 按钮 


用 户 填写 完 博客 主题 和 文章 内 容 后 ， 单 击 “ 提 交 ” 按 钮 ， 系 统 将 跳 转 到 处 理 页 (check filephp) 
进行 处 理 。 在 处 理 页 中 ,将 传 过 来 的 文章 标题 、 文 章 作者 和 文章 内 容 等 参数 组 成 insert 语句 ， 并 最 终 保 
存 到 数据 表 中 。 如 果 添 加 信息 成 功 ， 系 统 返回 到 本 页 ， 可 继续 执行 添加 操作 ;如 果 添 加 失败 ， 则 返 
到 上 一 步 ， 程 序 的 关键 代码 如 下 : 


加 
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<2php 

session start(); /开启 Session 支持 

include "Conn/conn php": /包含 数 据 库 连 接 文件 

if($btn 1—"){ // 判 断 传 值 页 面 
Stitle=$_POST[txt title]: // 取 得 文章 标题 
Sauthor=$_SESSION[usemame]: // 取 得 作者 
$content=$_ POST[file]: // 取 得 文章 内 容 
Snow=date("Y-m-d H:i:s"); // 使 用 date 函数 生成 发 布 时 间 


上 # 生成 insert 语句 */ 
$sql-"Insert Into tb_article (title,content,author,now) Values ('Stitle','Scontent','Sauthor','Snow')": 


Sresult-mysql_ query(SsqD: /执行 insert 语句 
族 根据 Sresult， 返 回 结果 */ 
isSresulb{ 
echo "<script>alert(' 恭 喜 您 ， 您 的 文章 发 表 成 功 !1):window-.location href-'file php':</script>": 
}else{ 
echo "<script>alert( 对 不 起 ， 添 加 操作 失败 !11"):history.go(-1):</script>"; 
} 
j}elsef 
echo "<script>alert( 对 不 起 ， 添 加 操作 失败 !11"):history.go(-1);</script>"; 
} 
?> 


25.7.4 ”文章 列表 的 实现 过 程 


铬 ma 视频 讲解 ， 光盘 \TMNVideo\2s\ 文 章 列 表 实现 过 程 .exe 
单 击 “ 文 章 管理 /我 的 文章 ” 超 链接 , 将 显示 用 户 发 表 过 的 文章 列表 , 文章 列表 页 面 (myfiles.php) 
的 运行 结果 如 图 25.21 所 示 。 


TT 


查看 我 的 文章 
世界 慌 划 杂 ,世界 入 简单 
2. 诊 情 每 一 个 表 在 

Kk: 1 这 ;2 条 


图 25.21 文章 列表 页 面 的 运行 结果 
文章 列表 页 面 使 用 了 分 页 技术 和 do…while 循环 语句 来 输出 文章 标题 。 程 序 关键 代码 如 下 : 


<2php 

session start(): /开启 Session 支持 
include "Conn/conn.php": // 包 含 数据 库 连 接 文件 
include "check login php": // 包 含 权限 检查 文件 
?> 

<!-- 分 页 -> 


<2php 
访 ”Spage 为 当前 页 ， 如 果 $page 为 空 ， 则 初始 化 为 1 */ 
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25.8.2 图片 上传 模块 技术 分 析 


铬 和 视频 讲解 ， 光 盘 \TM\VideoW25\ 图 片上 传 模块 技术 分 析 .exe 

博客 中 ， 用 户 除 了 可 以 发 表 文 章 ， 还 可 以 将 自己 的 照片 或 喜爱 的 图 片 发 布 到 网 上 ， 保 存 到 自己 的 
博客 中 。 文 字 信息 可 以 通过 简单 的 表单 保存 到 数据 库 中 ， 那 么 图 片 该 如 何 从 本 地 保存 到 服务 器 中 呢 ? 
与 保存 文件 类 似 ， 图 片 可 以 通过 上 传 的 方式 保存 到 服务 器 某 目 录 中 ， 也 可 以 转换 为 二 进 制 数 据 保 存 到 
数据 库 中 。 

1. 上 传 图 片 的 基本 流程 

上 传 图 片 到 服务 器 既 可 以 通过 FTP 实现 ， 也 可 以 通过 POST 方法 实现 。 本 系统 中 使 用 POST 方法 
实现 ， 采 用 这 种 方法 更 加 方便 ， 有 具体 实现 步骤 如 下 : 

(1) 在 <form> 表 单 中 定义 文件 选择 域 ， 用 来 选择 要 上 传 的 图 片 。 这 里 要 注意 ， 通 过 POST 方法 上 
传 文件 或 图 片 时 , 一 定 要 在 form 表单 中 加 上 属性 enctype="multipart/form-data", 否则 上 传 不 了 文件 (图 
Hs 

(2) 在 处 理 文件 上 传 的 页 面 中 ， 使 用 $_FILES 全 局 数组 来 判断 上 传 文件 类 型 和 上 传 文件 〈 图 片 ) 
大 小 是 否 符合 要 求 。 

$_FILES 数组 为 系统 预定 义 的 全 局 数组 ， 保 存 的 是 上 传 文件 〈 图 片 ) 的 相关 属性 。 使 用 格式 为 : 


$ FILES[name][property]: 


其 中 ， 第 一 维 的 键 值 name 要 与 上 传 表单 中 的 文件 选择 域名 相同 ， 第 二 维 的 键 值 property 的 取 值 说 
明 如 表 25.10 所 示 。 


表 25.10 $_FILES 的 相关 属性 


上 传 文件 的 类 型 


上 传 文件 的 大 小 
上 传 文件 在 服务 器 中 的 临时 文件 名 
上 传 文件 失败 的 错误 代码 


(3) 使 用 move_uploaded file0 函 数 上 传 文件 〈 图 片 ) 。 
(4) 返回 页 面 等 待 下 一 步 操作 。 
2. 使 用 POST 方法 上 传 图 片 
PHP 能 够 接受 任何 来 自 符合 RFC-1867 标准 的 浏览 器 (包括 Netscape Navigator 3 及 更 高 版 本 ; 
Microsoft Internet Explorer 3 加 微软 补丁 ， 或 者 更 高 版 本 ) 上 传 的 文件 。PHP 的 这 种 特性 使 用 户 既 可 以 
上 传 文本 文件 ， 也 可 以 上 传 二 进 制 文件 。 
下 面具 体 讲 解 如 何 使 用 POST 方法 上 传 图 片 或 文件 。 
利用 move uploaded file0 函 数 上 传 文件 ， 首 先 应 在 前 台 表 单 中 做 如 下 处 理 : 


<form enctype="multipart/form-data" action="URL" method="POST"> 
<input type="hidden" name="MAX FILE SIZE" value="30000"> 
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上 传 文件 路 径 : <input name="file" type="file"> 

<input type="submit" value= "上传 "> 

</form> 

上 述 代码 中 的 URL 应 该 蔡 换 成 指向 一 个 PHP 文件 的 真实 提交 地 址 ， 在 该 文件 中 将 使 用 
move_uploaded_file0 函 数 进行 文件 上 传 。 

取 值 为 MAX_FILE_SIZE 的 隐藏 域 (单位 为 字 节 ) 必须 先 于 文件 选择 框 ， 其 值 为 可 以 接收 的 文件 
的 最 大 尺寸 。 同 时 ， 要 保证 文件 上 传 表单 中 有 enctype="multipart/form-data" 的 属性 ， 否 则 文件 上 传 将 不 

实现 。 

MAX FILE SIZE 的 值 只 是 对 浏览 器 的 一 个 建议 ， 实 际 上 可 以 不 进行 设置 ，php.ini 文件 中 已 经 设 
置 了 允许 上 传 文件 的 最 大 值 。 但 最 好 还 是 在 表单 中 加 上 MAX FILE_SIZE， 因 为 它 可 以 避免 用 户 在 长 
时 间 等 待 大 文件 上 传 之 后 才 发 现 该 文件 过 大 的 麻烦 。 

为 上 传 文件 定义 的 变量 会 根据 PHP 的 版 本 及 设置 的 不 同 而 存在 差异 。 自 动 全 局 变量 $_ FILES 从 
PHP 4.1.0 版 本 开始 被 支持 。 在 这 之 前 ， 从 4.0.0 版 本 开始 ，PHP 支持 SHTITP POST _ FILES 数组 。 这 些 
数组 将 包含 所 有 关于 用 户 上 传 的 文件 的 信息 ， 这 里 推荐 使 用 $_FILES。 如 果 PHP 的 设置 选项 register_ 
globals 为 On, 则 相关 的 变量 名 也 将 会 存在 。 从 PHP 4.2.0 版 本 开始 , register_globals 的 默认 值 被 设 为 Off。 

$_FILES 数组 的 内 容 如 下 所 示 〔 假 设 文件 上 传 字段 的 名 称 为 fle) 。 

$_FILES ["file"]["name"] 

表示 客户 端 机 器 文件 的 原名 称 。 

$_FILES["file"]["type"] 

表示 文件 的 MIME 类 型 ， 需 要 浏览 器 提供 该 信息 的 支持 ， 如 “image/gif”。 

$_FILES["file"]["size"] 

表示 已 上 传 文件 的 大 小 ， 单 位 为 字 节 。 

$_FILES ["file"]["tmp_name"] 


表示 文件 被 上 传 后 在 服务 器 端 储存 的 临时 文件 名 。 
下 面 根据 一 段 代 码 介绍 如 何 使 用 函数 move_uploaded _file0 进 行文 件 上 传 ， 如 下 所 示 。 


function getname($exname) { 


$dir = "upimages/": // 定 义 上 传 文件 的 存储 路 径 
$i=1; 
if(!is_dir(3dir){ 
mkdir($dir.0777): // 判 断定 义 的 路 径 是 否 已 经 存在 ， 如 不 存在 则 创建 它 
} 
while(true){ 


if(!is_file($dir.$i.".".$exname)){ 
Sname=$i.".".$Sexname; 
break: /用 数字 加 扩展 名 作为 上 传 文件 的 存储 名 ， 如 果 该 文件 已 经 存在 ， 则 使 数字 加 1 后 再 存储 


} 
Si++: 
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} 
Teturn $dir.$name: 


} 
Sexname=strtolower(substr($_FILES['"upfile'][‘name'],(strrpos($_FILES["upfile']['name’]..)+1))): 
// 获 取 上 传 文件 的 扩展 名 

Suploadfile = gemame($exname): 

move_uploaded file($ FILES[upfile]['mp_name'], $uploadfile); 

上 述 代码 中 主要 应 用 到 函数 is_dir0、mkdir0 is_file0、strtolowerO、strpos0、move uploaded file0， 
下 面 将 逐一 介绍 这 些 函数 。 

回 is_dir0 函 数 

bool is_dir(string filename) 


is_dir0 函 数 的 作用 是 判断 该 函数 的 参数 是 否 是 一 个 目录 ， 如 果 该 参数 存在 而 且 是 一 个 目录 就 返回 
true， 和 否则 返回 false。 如 应 用 is_dir0 函 数 判断 “c:/mr” 是 否 为 目录 的 代码 如 下 : 
<?php 
iftis_dir("c:/mr") { // 判 断 c:/mr 是 否 为 目录 
echo "是 目录 !"; 
}else{ 
echo "不 是 目录 !"; 
b 


> 
回 mkdir0 函 数 
bool mkdir ( string pathname [, int mode]) 


mkdir0 函 数 的 作用 是 创建 由 pathname 指定 的 目录 。mode 在 Windows 下 被 忽略 ， 自 PHP 4.2.0 起 
为 可 选项 。 默 认 的 mode 为 0777， 表 示 最 大 可 能 的 访问 权 。 如 应 用 mkdir0) 函 数 在 当前 目录 下 建立 目录 
mr， 代 码 如 下 : 
<?php 
这 mkdiromr){ // 创 建 目录 mr 
echo "目录 建立 成 功 !"; 
}else { 
echo "目录 建立 失败 1"; 
} 
过 
回 is_file0 函 数 


bool is file(string filename) 


is_file0 函 数 的 作用 是 判断 flename 指定 的 文件 是 否 为 一 个 常规 文件 ， 如 果 该 文件 存在 而 且 是 常规 
文件 就 返回 trme， 否 则 返回 false。 如 应 用 is_file0 函 数 判断 “c:/mr/mr.txt” 是 否 为 合法 文件 ， 代 码 如 下 : 


<2php 
iftis_file("c:/mr/mr.txt")){ 。。”// 判 断 c:/mr/mr.txt 是 否 为 一 个 合法 文件 
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echo "是 合法 文件 "; 
Jelse{ 
echo "不 是 合法 文件 "; 
} 
?> 
加 ”strtolower0 函 数 
string strtolower(string str) 


strtolower0) 函 数 的 作用 是 将 str 中 的 字母 全 部 转换 成 小 写字 母 。 如 应 用 strtolower0 函 数 将 字符 串 中 
的 大 写字 母 转换 成 小 写字 母 。 其 代码 如 下 : 

<?php 

echo strtolower("PHP 函数 参考 手册 "); 


echo strtolower("JAVA 案例 精 选 "); 
?> 


本 示例 的 运行 结果 如 下 : 
php 函数 参考 手册 

java 案例 精 选 

回 stmpos(O 函 数 

int strrpos(string strl.char str2) 


strrpos() 函 数 的 作用 是 在 strl 中 查找 str2 首 字符 最 后 一 次 出 现 的 位 置 。 如 应 用 strrpos0 函 数 查找 指 
定 字符 在 字符 串 中 最 后 出 现 的 位 置 ， 代 码 如 下 : 

<?php 

echo strrpos("Hello world!","WO"); /区 分 大 小 写 ， 搜 索 失 败 

echo strrpos("T am fine 1","f",5): /从 第 5 个 字符 开始 搜索 ， 输 出 5 


echo strrpos(" 明 日 图 书 "," 图 书 "); // 输 出 4 
?> 


本 示例 的 运行 结果 为 : 54 
回 move_uploaded fileO 函 数 


bool move uploaded file ( string filename. string destination) 


Inove uploaded file0) 函 数 的 作用 是 将 filename 指定 的 文件 上 传 到 destination 指定 的 位 置 。 如 应 用 
move_uploaded_file0 函 数 将 “c:/mr/mr.rar” 上 传 到 服务 器 当前 目录 下 的 mrsoft 目录 中 ， 代 码 如 下 : 


<?php 

if(!is_dir(“mrsoft")){ 
mkdir("“mrsoft"): 

} 

这 move uploaded file("c:/mr/mr.rar",."mrsoft/mr.rar")){ 
echo "文件 上 传 成 功 !"; 

}else{ 

echo "文件 上 传 失败 1": 
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表 25.11 图 片上 传 页 面 中 的 表单 元 素 


元 素 类 型 | 元 素 名 称 
回 form | myform 

[text 
EE file 


属性 设置 
method="post" action="tpt] ok.php" enctype="multipart/form-data" | 图 片上 传 表单 
type="text" id="tpme" size="40" | 图 片 名 称 
ype="file" size="23" maxleng 
type="submit" id="btn_tj" value=" 提 交 " onClick="return pic_ chkO:" 


当 用 户 输入 图 片 名 称 , 并 选择 图 片 路 径 后 , 单 击 “ 提 交 ” 按 钮 , 系统 将 进入 到 上 传 处 理 页 (tpt}_ok.php) 
中 进行 处 理 。 在 处 理 页 中 ， 首 先 对 图 片 名 称 进行 处 理 ， 去 掉 特殊 字符 、 空 行 和 空格 ， 然 后 对 上 传 的 文 
件 进 行 类 型 检查 、 文 件 大 小 检查 。 最 后 以 二 进 制 的 形式 与 图 片 的 其 他 信息 〈 如 上 传 用 户 、 上 传 时 间 等 ) 
一 起 存 进 数 据 表 中 。 关 键 代码 如 下 : 


<2php 
session start(); // 开 启 Session 支持 
include "check login php": /包含 权 限 检查 文件 
include "Conn/conn.php": // 包 含 数据 库 连 接 文件 
if($_POST["btn_t"] 一 "提交 "){ 
Stpmc=htmlspecialchars($tpmc): // 将 图 片 名 称 中 的 特殊 字符 转换 成 HTML 格式 
Stpme=str_replace("\n","<br>",$tpme); // 将 图 片 名 称 中 的 回 车 符 以 自动 换行 符 取代 
Stpme=str_replace(™","&nbsp:",$tpmc): /将 图 片 名 称 中 的 空格 以 “&nbsp:” 取 代 
$author=$_SESSION[username]:; 
S$scsj=date("Y-m-d"); // 设 置 图 片 的 上 传 时 间 
Sprofix = array("jpg".".gif',"jpeg"): // 设 置 允许 上 传 的 文件 后 缀 类 型 
Sf name =$_FILES[file][name]: // 取 得 要 上 传 的 文件 名 
$pro_name=substr($f name,strrpos($f_ name,".")); // 取 得 上 传 文件 的 后 缀 


上 判断 上 传 文件 的 类 型 是 否 为 允许 类 型 */ 
if(!in_array(strtolower($pro_name), Sprofix)){ 
echo "<script>alert(' 文 件 格式 不 对 "):history.go(-1):</script>"; 
exitO: 


语 判断 上 传 文件 的 大 小 ， 如 果 文 件 过 大 ， 提 示 错 误 */ 
if($_FILES[file][size] > 500000){ 
echo "<script>alert( 文 件 上 传 错误 ,请 重新 上 传 ):history.go(-1)</script>"; 


exitO: 

}else{ 
Sfp=fopen($file,"r"): // 以 只 读 方 式 打开 文件 
Sfile=addslashes(fread($fp,filesize($file))): /将 文件 中 的 引号 部 分 加 上 反 斜 线 


$query="insert into tb_tpsc (tpmec.file.author.scsj) Values (Stpmec'.$file.Sauthor.$scsj)": 
S$result-mysql query($query): 
echo "<meta http-equiv=\"refresh\" content=\"1:url=browse_pic.php\"> 图 片上 传 成 功 ， 请 稍 等 …"; 


} 


和 


上 述 代码 中 , 主要 涉及 htmlspecialchars0 函 数 、str_replace0O 函 数 的 使 用 方法 ， 这 两 个 函数 在 处 理 字 
符 串 时 经 常会 用 到 ， 下 面具 体 介绍 这 两 个 函数 的 使 用 方法 。 
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回 htmlspecialchars 0 函数 
string htmlspecialchars(string string) 


该 函数 将 一 些 特殊 字符 转换 成 HTML 格式 , 而 不 会 将 所 有 字符 都 转换 成 HTML 格式 。 该 函数 转换 
的 特殊 字符 如 表 25.12 所 示 。 


表 25.12 htmlspecialchars() 函 数 转换 的 特殊 字符 


参数 说 明 
&& (和) 转 成 &amp: 
““ ”( 双 引号 ) 转 成 &quot:; 
> (大 于 号 ) 转 成 &gt: 
< 小 于 号 ) 转 成 &lt: 


例如 ， 应 用 htmlspecialchars() 函 数 将 特殊 字符 转换 成 HTML 格式 ， 代 码 如 下 : 


$str='<table width="371" border="0"> 特 殊 字符 的 转换 </table>'; 
echo htmlspecialchars($str):; 

本 示例 的 运行 结果 如 下 : 

<table width="371" border="0"> 特 殊 字符 的 转换 </table> 
回 str_replace (函数 


mixed str_replace ( mixed search, mixed replace, mixed subject , int &count ) 
str_replace() 函 数 将 所 有 在 参数 subject 中 出 现 的 search 以 参数 replace 蔡 换 ， 参 数 &count 表示 替换 
字符 串 执行 的 次 数 。 
str_replace() 函 数 的 参数 说 明 如 表 25.13 所 示 。 
表 25.13 str_replace() 函 数 的 参数 说 明 


参数 说 了 明 

search 指定 将 要 被 蔡 换 的 字符 
replace 指定 蔡 换 所 使 用 的 字符 
subject 指定 被 操作 的 字符 串 
&count 替换 字符 串 执行 的 次 数 


例如 ， 应 用 str_replace0 函 数 实现 对 字符 串 的 替换 ， 代 码 如 下 : 


<?php 

S$str = "吉林 省 明日 科技 ": 

S$strl =array(" 明 日 软件 ", "明日 图 书 ", "明日 论坛 "); 

$str2 =array(" 明 日 "); 

Sstrs = str_replace($str2, $str, $str1):; 

Print r($strl): /输出 蔡 换 前 的 结果 

Print r($strs): /输出 茜 换 后 的 结果 

$str = str_ Teplace("mrsoft". "吉林 省 明日 科技 有 限 公 司 ", "Welcome to mrsoft!", $count); 
echo "Welcome to mrsoft!"; 
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echo $str: /输出 蔡 换 后 的 结果 
echo $count: /输出 蔡 换 字符 的 次 数 
?> 


25.8.4 ”图 片 浏 览 的 实现 过 程 


健 1 视频 讲解 ， 光盘 \TM\VideoW25\ 图 片 浏览 的 实现 过 程 .exe 

本 页 的 实现 代码 与 查看 文章 页 面 略 有 不 同 ， 查 看 文章 页 面 中 ， 每 条 数据 占 了 一 行 ， 而 查看 图 片 则 
采用 的 是 分 栏 显 示 ， 以 每 行 两 张 图 片 的 格式 输出 ， 每 页 显示 4 张 图 片 。 通 过 单 击 小 图 片 ， 可 以 查看 图 
片 原 效果 图 。 图 片 浏览 页 面 运行 效果 如 图 25.25 所 示 。 


下 
0 本 2 要 


图 25.25 浏览 图 片 页 面 的 运行 结果 
实现 图 片 浏览 的 关键 代码 如 下 : 


<?php 

session start(); // 开 启 Session 支持 
include "Conn/conn.php": // 包 含 数据 库 连 接 文 件 
include "check login.php"; // 包 含 权限 检查 文件 


?> 
<!-- 首 部 导航 栏 --> 
<t> 
<td height="192" align="center" valign="top" > 
<?php 
// 分 页 显示 
$query="select * from tb_tpsc where scsj order by id desc limit $offset, Spage_size": 
人 # 返回 结果 集 */ 
Sresult=mysql_ query($query): 
?> 


<table width="496" border="1" align="center" cellpaddine="3" cellspacine="1" bordercolor="#D6D7D6"> 
<tr> 


<2php 
全 设置 一 个 变量 ， 判 断 当前 数据 是 奇数 输出 还 是 偶数 输出 */ 
$i=1:; 
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"52" height="16" alt=" 删 除 图 片 " onClick="returmn pic_ chk0:"></a> 
<?php 


让 ”变量 $i 自 加 1，while 循环 结束 */ 
Sit+; 
} 
> 
</> 


通过 上 述 代码 可 以 发 现 ， 预 览 图 片 和 显示 图 片 实际 调用 的 都 是 同一 页 面 image.php。image.php 页 
用 来 显示 图 片 的 实际 效果 ， 实 现代 码 很 简单 ， 如 下 所 示 。 


<?php 
include "Conn/conn.php"; // 包 含 数据 库 连 接 文 件 
Squery="select id,tpmc,file.author.scsj from tb_tpsc where id=".$_GET['recid’]: /根据 ID 生成 查询 语句 
Sresult=mysql_query($query): // 执 行 查询 语句 
这 !$resulb die("error: mysql query"): /判断 是 否 有 返回 结果 
Snum=mysql_num rows(S$result): // 计 算 结果 集 个 数 
if($num<1) die("error: no this recorder"): 
Sdata = mysql_result($result.0."file"): // 返 回 图 片 数 据 
echo $data: // 输 出 图 片 
2 


25.8.5 ”删除 图 片 的 实现 过 程 


铬 4 视频 讲解 ， 光盘 \TM\Video\25\ 删 除 图 片 的 实现 过 程 .exe 
在 博客 中 ， 不 能 保证 每 个 用 户 所 发 表 的 文章 或 照片 都 是 合法 的 ， 为 了 保证 博客 能 够 正常 运营 、 保 
持 良 好 的 形象 ， 管 理 员 需 要 及 时 将 一 些 非法 内 容 进 行 删除 。 本 博客 中 用 于 删除 图 片 的 关键 代码 如 下 : 


<?php 
session start(): // 开 启 Session 支持 
include "check login .php": /包含 权 限 检查 文件 
include "Conn/conn .php": /包含 数 据 库 连接 文件 
if($_session[fig] (= "1"){ // 判 断 是 否 为 管理 员 

echo "<script>alert(' 您 没有 删除 权限 "):history.go(-1):</script>"; 

> 
$sql="delete from tb_tpsc where id=".$_GET['pic id]: // 生 成 删除 语句 
$result=mysql_query($sqD):; // 执 行 删除 语句 
if(Sresul) { // 根 据 $result 返回 结果 


echo "<script>alert( 图 片 删除 成 功 !"):location='browse_pic.php':</script>"; 


} 


else{ 
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echo "<script>alert( 图 片 删 除 操作 失败 !"):history.go(-1):</script>"; 
> 
?> 
上 述 代 码 中 ， 首 先 使 用 $_GET[] 全 局 数组 接收 通过 GET 方法 传递 的 图 片 的 ID 值 ， 然 后 使 用 
mysql_query0 函 数 执行 查询 ， 根 据 该 ID 值 删除 指定 的 图 片 。 


25.9 ”朋友 圈 模 块 设计 


在 博客 中 除了 可 以 发 表 文 章 和 上 传 图 片 或 照片 外 ， 还 可 以 结交 一 些 网 络 朋 友 ， 本 博客 的 朋友 图 模 
块 即 可 为 用 户 提 供 相互 交流 的 平台 。 


25.9.1 ”朋友 圈 模 块 概述 


通过 本 博客 的 朋友 圈 模 块 ， 用 户 可 以 对 好 友信 息 进行 添加 、 查 询 和 删除 等 操作 。 为 了 保证 用 户 隐 
私 不 会 泄露 ， 用 户 所 添加 的 好 友信 息 只 有 本 人 可 以 看 到 ， 其 他 用 户 即 使 管理 员 也 不 能 随意 查看 。 如 果 
博客 中 出 现 恶意 用 户 ， 并 且 被 管理 员 删 除 ， 那 么 该 用 户 的 朋友 圈 也 一 并 被 删除 。 朋 友 圈 模块 框架 图 如 
图 25.26 所 示 。 


1 
1 
好 友 列表 


图 25.26 朋友 圈 模 块 框架 图 
25.9.2 ”朋友 轿 模 块 技术 分 析 


芯 a 视频 讲解 ， 光盘 \TM\Video\25\ 朋 友 圈 模 块 技术 分 析 .exe 

为 了 有 效 查 询 朋 友 圈 中 的 好 友信 息 ， 该 模块 中 使 用 模糊 查询 的 方式 对 好 友信 息 进行 检索 。SQL 语 
言 中 使 用 关键 字 like 实现 数据 库 中 信息 的 模糊 查询 ， 一 般 采 用 如 下 两 种 方式 对 数据 库 中 的 信息 进行 模 
糊 查询 。 

1. 使 用 通配符 “%” 的 where 子 句 

通配符 “%” 表 示 0 个 或 多 个 、 任 意 长 度 和 类 型 的 字符 ， 包 括 汉字 。 

示例 1: 表示 查找 所 有 内 容 中 包含 “好 ” 字 的 文章 。 
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select * 位 om tb _file where content like '% 好 %'; 
示例 2: 查找 所 有 包含 “好 ” 字 或 “高 ” 字 的 文章 ， 这 时 可 以 配合 or 运算 符 来 使 用 ， 代 码 如 下 。 
select * from tb_file where content like '% 好 %' or content like '% 高 %6'; 
2. 使 用 通配符 “_” 的 where 子 句 


通配符 “_” 表 示 匹 配 任意 的 单个 字符 。 
示例 1: 查找 用 户 名 只 包含 5 个 字符 ， 其 中 后 4 个 字符 为 soft 的 用 户 ， 代 码 如 下 。 


select * from tb _user where regname like' soft: 

示例 2: 查找 所 有 以 t 开 头 ， 并 且 以 t 结 尾 的 、 中 间 包 含 3 个 字符 的 用 户 ， 代 码 如 下 。 
select * from tb user where regname Hike tt: 

查找 的 结果 为 : tsoft。 


< 注意 : 使 用 MySQL 进行 模糊 查询 要 注意 编码 问题 。 如 果 编 码 不 统一 ， 那么 查询 时 就 容易 查 不 到 数 
据 ， 或 返回 的 数据 不 匹配 。 所 以 在 安装 MySQL 时 ， 要 保持 和 系统 编码 的 统一 。 常 用 的 编码 
格式 有 GB2312、ISO-8859-1、UTF-8 和 GBK 等 。 


25.9.3 ”查询 好 友 的 实现 过 程 


铬 m 视频 讲解 ， 光盘 \TMVideov2s\ 查 询 好 友 的 实现 过 程 .exe 

单 击 “ 朋 友 圈 管理 ”/“ 查 询 朋 友信 息 ” 超 链接 即 可 进入 查找 好 友 圈 模块 ， 如 图 25.27 所 示 。 查 找 
好 友 时 首先 在 “查询 条 件 ”下 拉 列 表 框 中 选择 按 什么 条 件 进行 查询 ， 然 后 在 “关键 字 ” 文 本 框 中 输入 
要 查询 的 关键 字 ， 最 后 单 击 “ 检 索 ” 按 钮 即 可 查找 出 相关 的 好 友信 息 。 


é 谈 闲 人 
DXR 的 博客 
en 


Er 


Ed i 
图 25.27 查询 好 友 页 面 的 运行 结果 
查询 页 面 所 涉及 的 表单 及 表单 元 素 说 明 如 表 25.14 所 示 。 
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表 25.14 ”查询 好 友 页 面 的 表单 及 表单 元 素 


元 素 类 型 元 素 名 称 属性 设置 含义 
| method="post" action="query _ friend.php" onSubmit= "return 
图 form myform kg 2 os Wy | 查询 好 友 表 单 
check0: 
<option value="name" selected> 姓 名 </option> 
select | sel ti i value="id"> 编 号 </option> ” | 查询 条 件 选择 
区] text | sel key |ig="sel key" size="30" | 查询 关键 字 
辐 ] submit submit type="submit" name="submit" value=" 检 索 " 提交 按钮 


查询 处 理 页 通过 POST 方法 接收 到 查询 条 件 及 查询 关键 字 后 ， 根 据 提交 关键 字模 糊 查 询 语句 ， 执 


行 SQL 语句 并 返回 查询 结果 。 如 果 没 有 输入 关键 字 ， 则 弹出 提示 框 ， 如 果 没 有 查找 到 任何 结果 ， 则 输 
出 “Sory! 没 有 您 要 找 的 朋友 !”。 查 询 处 理 页 的 关键 代码 如 下 : 
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<?php 

session_ start(); // 开 启 Session 支持 
include "Conn/conn.php": // 包 含 数据 库 连 接 文件 
include "check login.php": // 包 含 权 限 检查 文件 
?> 


<script language="javascript"> 
让 JavaScript 脚本 ， 验 证 输入 信息 ， 如 果 为 空 ， 则 弹出 提示 框 */ 
function check(form){ 
if (document.myform.sel key.value—""){ 
alert(" 请 输入 查询 条 件 !"); 
myform.sel_ key.focus(): 


return false; 

} 

</script> 

<?php 

if($_POST[sel key]!=""){ 
$tj=$_POST[sel 1j]: // 接 收 查 询 字 段 
Skey=$_POST[sel key]: // 接 收 查 询 关键 字 
$sql=mysql query("select * 位 om tb friend where $tj like '%S$key%' and username='$ SESSION[usernamel"); 
Sresult=mysql_fetch_array($sql): // 执 行 查询 语句 
这 Sresult 一 false){ 
echo ("[<font color=red>Sorry! 没 有 您 要 找 的 朋友 !</font>]"): 

}else{f 


人 > 
<!-- 显示 记录 表单 ” --> 
<?php 

> 
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25.10 项 目 发 布 


将 网 站 发 布 到 Internet 的 方法 有 多 种 , 最 常用 的 方式 有 使 用 独立 服务 器 发 布 站 点 和 租用 虚拟 主机 空 
间 发 布 站 点 。 


25.10.1 通过 个 人 服务 器 发 布 项 目 


镶 视频 讲解 ， 光 盘 \TM\Video\25\ 通 过 个 人 服务 器 发 布 项 目 .exe 
完成 网 站 的 开发 后 ， 还 需要 将 网 站 发 布 到 Intemet 中 ， 如 果 使 用 独立 IP 并 且 拥 有 自己 的 服务 器 ， 
那么 发 布 网 站 相对 简便 ， 只 需 安装 PHP 运行 环境 并 填写 独立 IP 地 址 ， 并 将 申请 的 域名 解析 到 服务 器 
IP 即 可 。 如 果 希 望 在 一 台 服 务 器 上 运行 多 个 站 点 ， 那 么 可 以 配置 Apache 服务 器 的 httpd.conf 文件 中 
Virtual Hosts 模块 。 
例如 ， 在 独立 瑟 为 221.8.65.** 的 服务 器 中 发 布 网 站 www.mingri**.com 和 www.mr**.com。 
(1) 正确 填写 服务 器 他 地 址 、 域 名 地 址 等 信息 。 
(2) 将 www.mingri**.com 和 www.mr**.com 都 解析 到 221.8.65.** 这 个 地 址 。 
(3) 配置 httpd.conf 文件 (假设 www.mingri**.com 域名 所 对 应 的 站 点 文件 存放 在 服务 器 c 盘 的 
mingri** 目 录 下 ，www.mr**.com 存放 在 c 得 的 mr** 下 ) 。 


<VirtualHost *:80> 
DocumentRoot c:/mingri** 
ServerName www.mingri**.com 
</VirtualHost> 


<VirtualHost *:80> 
DocumentRoot c:/mr** 
ServerName Www.mr**.com 
</VirtualHost> 


(4) 将 项 目 文件 分 别 复制 到 指定 的 目录 中 。 
(5) 重新 启动 Apache 服务 器 生效 。 


25.10.2 ”通过 租用 空间 发 布 项 目 


铝 a 视频 讲解 ， 光盘 \TMvideo\2s\ 通 过 租用 空间 发 布 项 目 .exe 

要 使 用 租用 虚拟 主机 空间 的 方式 发 布 站 点 , 需要 经 过 注册 域名 、 申 请 空间 、 解 析 域 名 和 上 传 网 站 4 
个 步 又。 首先 介绍 一 下 注册 域名 。 

1. 域名 申请 

域名 就 是 用 来 代替 人 P 地 址 ， 以 方便 记忆 及 访问 网 站 的 名 称 。 例 如 ，www.mingribook.com 就 是 明 
日 图 书 网 的 域名 ，www.yahoo.com.cn 就 是 中 文雅 虎 的 域名 。 域 名 需要 到 指定 的 网 站 中 注册 购买 ， 如 
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www.net.com (万 网 ) 和 www.xinnet.com (新 网 ) 等 。 

购买 注册 域名 的 步骤 如 下 : 

(1) 登录 域名 服务 商 网 站 。 

(2) 注册 会 员 。 如 果 不 是 会 员 则 无 法 购买 域名 。 

(3) 进入 域名 查询 页 面 ， 查 询 要 注册 的 域名 是 否 已 经 被 注册 。 

(4) 如 果 用 户 欲 注册 的 域名 未 被 注册 ， 则 进入 域名 注册 页 面 ， 在 该 页 面 中 填写 相关 的 个 人 资料 。 

(5) 填写 成 功 后 ， 单 击 “ 购 买 ”按钮 ， 注 册 成 功 。 

(6) 付款 后 ， 等 待 域名 开启 。 

2. 申请 空间 

域名 注册 完毕 后 ， 下 一 步 是 申请 空间 。 空 间 可 以 使 用 虚拟 主机 或 租借 服务 器 。 目 前 ， 许 多 企业 建 
立 网 站 都 采用 虚拟 主机 ， 这 样 既 节 省 了 购买 机 器 和 租用 专线 的 费用 ， 同 时 也 不 必 聘 用 专门 的 管理 人 员 
来 维护 服务 器 。 申 请 空间 的 步骤 如 下 : 

(1) 登录 虚拟 空间 服务 商 网 站 。 

(2) 注册 会 员 〈 如 果 已 有 会 员 账号 ， 则 直接 登录 即 可 ) 。 

(3) 选择 虚拟 空间 类 型 〈 空 间 支 持 的 语言 、 数 据 库 、 空 间 大 小 、 流 量 限 制 等 ) 。 

(4) 确定 机 型 后 ， 直 接 购买 。 

(5) 进入 到 缴费 页 面 ， 选 择 缴费 方式 。 

(6) 付费 后 ， 空 间 在 24 小 时 内 开通 ， 随 后 即 可 使 用 此 空间 。 

3. 将 域名 解析 到 服务 器 

域名 和 空间 购买 成 功 后 ， 接 下 来 需要 将 域名 地 址 指向 虚拟 服务 器 的 卫 。 进 入 域名 管理 页 面 ， 添 加 
主机 记录 。 一 般 先 要 输入 主机 名 ， 注 意 不 包括 域名 。 例 如 ， 解 析 www.bccd***.com， 如 果 要 添加 该 主 
机 ， 只 需 输 入 www 即 可 ， 后 面 的 bccd***.com 不 需要 填写 。 接 下 来 填写 IP 地 址 。 最 后 单 击 “ 确 定 ” 
按钮 ， 剩 下 的 工作 交 给 域名 服务 器 即 可 。 如 果 想 添加 多 个 主机 名 ， 则 重复 上 面 的 操作 即 可 。 

4. 上 传 网 站 


最 后 就 是 上 传 网 站 程序 。 上 传 网 站 需要 使 用 FTP 软件 。 如 果 使 用 Dreamweaver， 则 可 以 直接 在 

Dreamweaver 中 上 传 。 这 里 以 CuteFTP 为 例 讲 解 上 传 步 又 。 

(1) 打开 FTP 软件 。 

(2) 选择 File/Site-Manager 命令 ， 弹 出 站 点 面板 。 

(3) 单 击 New 按钮 ， 新 建 一 个 站 点 。 

(4) 在 Label for site 文本 框 中 输入 站 点 名 。 

(5) 在 FTP Host Address 文本 框 中 输入 域名 。 

(6) 在 FTP site User Name 文本 框 中 输入 用 户 名 。 

(7) 在 FTP site Password 文本 框 中 输入 密码 。 

(8) 单 击 Edit 按钮 ， 弹 出 编辑 窗口 。 

(9) 选中 Use PASV mode 和 Use firewall setting 复 选 框 。 

(10) 单 击 “ 确 定 ” 按 钮 。 

(11) 单 击 Connet 按钮 连接 到 服务 器 。 
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(12) 连接 服务 器 后 ， 在 左 侧 的 本 地 页 面 中 右 击 需 要 上 传 的 文件 ， 单 击 “ 上 传 ” 按 钮 即 可 。 
(13) 如 果 上 传 过 程 中 出 现 错误 ， 选 择 “ 继 续 上 传 ” 命 令 即 可 。 
(14) 上 传 成 功 后 ， 关 闭 FTP 软件 。 


25.11 开发 常见 问题 与 解决 


铬 ml 视频 讲解 ， 光盘 \TM\Video\25\ 开 发 常见 问题 与 解决 .exe 

在 项 目 开发 过 程 中 ， 免 不 了 会 遇 到 一 些 问题 ， 其 实 问题 并 不 可 怕 ， 关 键 是 需要 开发 人 员 能 够 认真 
细心 地 去 面 对 、 去 解决 。 下 面 将 介绍 如 何 处 理 和 解决 博客 开发 过 程 中 常见 的 问题 。 

1. 数据 库 乱码 问题 

首先 查看 本 博客 的 数据 库 连 接 文件 ， 代 码 如 下 : 


<?php 

S$link=mysql_connect("localhost","root","root"): // 建 立 与 MySQL 数据 库 的 连接 
mysql_select_db("db_blog",Slink): // 选 择 数据 库 
mysql_query("'set names gb2312"); // 设 置 字 符 集 


> 


最 初 在 开发 本 博客 时 ， 并 没有 加 上 “mysql_query("set names gb2312")” 这 人 句 代码 ， 可 是 在 调试 程 
序 时 ， 发 现 从 数据 库 提取 的 所 有 中 文字 符 都 为 乱码 ， 如 图 25.28 所 示 。 


| 适用 人 sn 


PU 


洪 信 容量 新 文章 


图 25.28 中文 乱码 问题 


这 是 没有 正确 设置 数据 库 中 的 字符 集 所 导致 的 乱码 错误 。“mysql_query("set names gb2312")” 这 
句 代 码 的 作用 就 是 设置 MySQL 数据 库 的 字符 集 为 GB2312， 当 然 也 可 以 使 用 这 人 句 代码 设置 MySQL 数 
据 库 的 字符 集 为 其 他 类 型 ， 如 UTF-8 等 。 


2. 接收 GET 方法 或 POST 方法 提交 数据 问题 
在 接收 GET 方法 或 POST 方法 提交 的 数据 时 ， 一 般 使 用 $_GET 或 $ POST 全 局 数组 进行 接收 。 
在 实际 开发 过 程 中 ， 有 时 不 用 这 两 个 全 局 数组 进行 接收 ， 而 直接 用 与 传递 的 参数 同名 或 与 提交 表 
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请 耐心 等 待 或 者 刷新 重 试 


PAT 


应 用 Smarty 名 机 于 有 和 1 
(全 视频 讲解 ，281 分 钟 ) 


电子 商务 《Electronic Commerce) ， 简 称 EC， 是 指 整个 事务 活动 和 贸易 活动 
的 电子 化 ， 它 通过 先进 的 信息 网 络 ， 将 事务 活动 和 贸易 活动 中 发 生 关 系 的 各 方 有 机 
地 联系 起 来 。 电 子 商务 网 站 实际 上 就 是 企业 为 消费 者 提供 的 网 上 虚拟 购物 商城 ， 在 
该 网 站 中 ， 用 户 可 以 购买 任何 商品 ， 而 管理 员 可 以 对 商品 和 订单 等 信息 进行 管理 。 
通过 本 章 的 学 习 ， 读 者 不 仅 可 以 丰富 自己 的 基础 知识 、 训 担 大 量 网 站 制作 技巧 及 
PHP 常用 函数 的 使 用 方法 ， 更 能 事 担 网 络 编程 的 设计 思路 、 方 法 和 过 程 ， 快 速 提高 
PHP 开发 能 力 和 设计 水 平 。 

通过 阅读 本 章 ， 可 以 学 习 到 : 

由。 如何 进行 系统 分 析 

让 如 何 编写 项 目 计划 书 
数据 库 设 计 流 程 
搭建 系统 架构 
简单 的 树 状 菜单 
如 何 灵 活 运用 JS 和 Ajax 技术 
如 何 灵 活 运用 购物 车 
如 何 灵 活 运用 Smarty 模板 开发 程序 
ADODB 在 实际 中 的 应 用 


总 吾 于 于 于 于 至 


PHP 开发 实战 宝典 


26.1 项 目 描述 


开发 电子 商务 平台 实质 上 就 是 建立 一 个 虚拟 的 购物 超市 ， 当 在 超市 选 购 商品 时 ， 首 先 应 该 将 商品 
放 到 购物 车 中 ， 待 挑选 好 所 有 商品 之 后 就 可 以 到 收银 台 去 结算 ， 根 据 结算 单据 付款 。 开 发 电子 商务 平 
台 的 原理 与 在 超市 购物 的 原理 是 相同 的 : 客户 通过 网 页 浏览 商品 ， 选 购 自 己 喜 欢 的 商品 ， 将 商品 放 入 
购物 车 中 ， 当 然 也 可 以 改变 购买 商品 的 数量 或 者 清空 购物 车 中 的 商品 ， 在 选 购 好 商品 后 到 收银 台 去 结 
算 ， 生 成 订单 ， 填 写 并 提交 收 货 人 信息 ， 最 终 按照 订单 中 提交 的 付款 方式 进行 付款 ， 等 待 送 货 上 门 ， 
期 间 还 可 以 登录 平台 查看 自己 的 订单 。 

企业 就 是 这 个 虚拟 超市 的 管理 者 ， 可 以 对 登录 的 用 户 、 商 品 信息 、 商 品类 别 、 订 单 和 公告 等 内 容 
进行 管理 。 

本 系统 建立 一 个 电子 商务 平台 ， 实 现 网 上 购物 的 功能 ， 包 括 从 客户 最 初 的 商品 浏览 到 最 后 的 购物 
结算 、 订 单 查看 ， 以 及 企业 的 商品 信息 、 商 品类 别 、 客 户 信息 和 订单 的 管理 。 

系统 开发 应 用 PHP 语言 +MySQL 数据 库 ， 通 过 Smarty 模板 实现 网 页 动静 分 离 ， 通 过 ADODB 操 
作 数 据 库 ， 其 中 还 应 用 到 Ajax、Fram 框架 、JavaScript、CSS 和 DIV 等 技术 。 

系统 中 典型 的 功能 模块 是 : 找 回 密码 、Ajax 无 刷新 注册 验证 、GD2 图 像 验 证 码 、 购 物 车 、 收 银 台 、 
树 状 菜单 和 商品 信息 管理 。 


26.2 系统 分 析 


26.2.1 ”需求 分 析 


中 国 的 市 场 经 济 日 趋 成 熟 ， 中 国企 业 面 对 的 竞争 压力 也 越 来 越 大 ， 企 业 正在 寻求 一 种 高 效 、 便 于 
客户 购物 和 支付 的 购物 形式 ， 而 电子 商务 这 种 新 的 商业 运营 模式 完全 符合 商家 们 的 要 求 ， 同 时 也 可 以 
满足 消费 者 的 需求 。 消 费 者 能 够 在 网 上 实现 互动 的 交流 及 足 不 出 户 地 购买 产品 ， 向 企业 发 表 自己 的 意 
见 、 服 务 需 求 及 有 关 投 诉 ， 并 且 可 以 通过 网 站 的 交互 式 操作 向 企业 进行 产品 的 咨询 ， 以 此 来 获取 相应 
的 回馈 信息 及 技术 支持 。 

电子 商务 被 越 来 越 多 的 商家 和 消费 者 认同 ， 必 将 成 为 21 世纪 网 络 发 展 的 主流 ， 而 网 上 购物 将 成 为 
一 种 购物 时 尚 。 目 前 国内 企业 正 纷纷 加 入 到 阿里 巴巴 等 一 系列 大 型 电子 商务 网 站 中 , 通过 网 络 进行 B2B 
(企业 对 企业 ) 的 网 上 交易 之 后 ， 也 充分 认识 到 网 络 交易 将 成 为 未 来 商品 交易 的 重要 组 成 部 分 ， 在 通 
过 网 络 宣传 企业 的 同时 ， 也 逐步 扩大 企业 自身 的 网 络 销售 渠道 ， 建 立 起 自己 的 电子 商务 平台 ， 完 成 了 
从 B2B 到 B2C (企业 对 个 人 ) 进行 网 络 交易 的 过 渡 ， 大 大 提高 了 企业 的 经 济 效益 。 因 此 ， 企 业 开 发 属 
于 自己 的 电子 商务 平台 已 经 势 在 必 行 。 


26.2.2 ”编写 项 目 计划 书 
项 目 计划 书 是 项 目 负 责 人 写 给 投资 者 的 一 份 详细 的 开发 报告 ， 包 括 开发 背景 、 开 发 原因 、 可 行 性 
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项 目 开发 背景 

自 20 世纪 90 年 代 ， 互 联网 的 蓬勃 发 展 ， 为 企业 提供 了 一 个 全 新 的 机 遇 。 企 业 网 站 、 电 
子 商务 成 为 热门 话题 。 其 中 ， 电 子 商务 更 是 关系 到 经 济 结构 、 产 业 升级 和 国家 整体 经 济 竞 争 
力 。 为 此 ， 我 国 已 经 将 发 展 电子 商务 列 为 信息 化 建设 的 重要 内 容 ， 并 努力 创造 条 件 ， 积 极地 
推进 电子 商务 的 发 展 。 

据 美国 在 线 (AOL) 和 Henley Centre 联合 进行 的 一 项 调查 显示 : 国外 有 80% 的 受 调查 者 
会 选择 网 上 购物 或 寻求 帮助 ，10% 的 受 调查 者 会 选择 熟悉 的 品牌 或 厂商 来 购买 。 而 在 国内 ， 
自 1997 年 拉 开 了 电子 商务 的 序幕 ， 短 短 的 10 年 时 间 里 ， 全 国 已 有 4 万 家 商业 网 站 ， 几 乎 每 
天 都 有 新 的 网 站 诞生 ， 厂 商 所 在 地 也 从 上 海 、 广 州 、 深 圳 等 沿海 发 达 地 区 扩展 到 全 国 各 大 中 
城市 。 

二 、 电 子 商 务 的 概念 及 特点 

电子 商务 (Electronic Commerce) ， 简 称 EC， 是 目前 发 展 较 快 的 一 种 商务 模式 。 不 同 领 
域 的 人 群 对 EC 的 理解 各 有 不 同 ， 综 合 来 说 ， 电 子 商 务 是 通过 互联 网 进行 的 商务 活动 ， 它 已 
经 渗透 了 各 个 领域 ， 如 服务 、 金 融 、 销 售 等 。 

目前 来 说 ， 电 子 商务 主要 有 两 种 模式 。 一 种 是 纯粹 的 电子 商务 网 站 ， 如 阿里 巴巴 ， 它 为 
交易 双方 提供 了 一 个 丰富 的 信息 平台 ， 另 一 种 是 传统 产业 的 电子 商务 模式 ， 它 借助 互联 网 进 
行 特定 商品 的 销售 及 采购 。 

三 、 电 子 商务 的 优势 

电子 商务 的 优势 是 显而易见 的 ， 主 要 有 以 下 几 个 方面 

@ ”大 大 节约 了 企业 的 成 本 预算 ， 如 人 人工 费 、 场 地 费 等 。 

@。 ”降低 了 产品 的 零售 价格 。 因 为 是 和 消费 者 直接 交流 沟通 ， 取 消 了 代理 、 批 发 、 商 场 

等 费用 ， 在 同行 业 的 竞争 中 占据 优势 。 

@ 扩展 了 业务 范围 ， 只 要 能 够 上 网 的 人 ， 就 有 机 会 成 为 客户 ， 一 定 程度 上 消除 了 地 域 
的 影响 。 
@ 
@ 


加 速 了 资本 流通 。 
实现 24 小 时 连续 服务 。 

A 
市 场 前 景 。 数 据 表明 : 2007 年 中 国 B2B 电子 商务 交易 规模 为 12500 亿 元 ， 比 2006 
年 增长 25.5%。 预 计 未 来 两 年 我 国 B2B 电子 商务 交易 规模 将 继续 高 速 增长 ，2008 
年 将 达到 约 16200 亿 元 ，2009 年 交易 规模 有 望 达 21300 亿 元 。B2C 网 站 总 收入 为 
52.2 亿 元 ，2009 年 有 望 达到 98.6 亿 元 。 而 且 ， 随 着 网 络 购物 环境 的 好 转 ， 未 来 两 
年 B2C 电子 商务 交易 模式 将 更 受 欢 迎 , 用 户 数 和 年 平均 消费 金额 均 会 提高 。 这 里 所 
蕴含 的 商机 毋庸 置疑 。 

@ ”技术 可 行 性 。 电 子 商 务 相 关 的 技术 (如 认证 加 密 技术 、 数 据 备份 技术 、 网 上 交易 技 
术 ) 已 经 十 分 完善 ， 能 够 保障 系统 正常 、 无 错 地 运行 。 
@。 经济 可 行 性 。 通过 网 络 进行 商务 活动 ， 可 以 足 不 出 户 地 完成 交易 。 既 可 节省 交通 费 ， 又 

减少 了 务工 人 员 费 用 ， 同 时 ， 前 期 可 以 使 用 小 型 服务 器 或 虚拟 空间 以 减少 成 本 预算 。 

五 、 项 目 实施 的 技术 方案 

为 了 节约 成 本 ， 使 用 PHP 做 开发 ， 数 据 库 使 用 MySQL。 

采用 Smarty 模板 ， 可 以 最 大 限度 地 加 快 网 页 访问 速度 。 

考虑 到 以 后 可 能 升级 数据 库 ， 使 用 ADODB 类 库 连 接 。 

使 用 Ajax 技术 来 提高 交互 性 。 

提供 多 种 付款 方式 ， 包 括 网 银 、 邮 购 、 汇 款 等 。 

提供 在 线 咨询 。 
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电子 商务 平台 项 目 计划 书 
@ ”操作 简单 容易 ， 只 需要 简单 指点 便 可 使 用 ， 无 须 专 业 人 员 。 
六 、 总 体 投入 
报价 
顶级 域名 .com 或 .net 结尾 (英文 域名 ) 圣 100/ 年 
智 尊 U300 (250MB/ 赠 送 125MB ”邮局 
虚拟 主机 /SOMB mysql/php/perl) 六 750/ 年 
圣 20000/ 套 (包括 一 年 的 免费 维护 ， 如 
电子 商务 平台 | 电子 商务 网 上 交易 系统 需 一 次 开发 费用 另 算 ) 
用 户 提交 留言 ， 不 需 审核 立即 显示 ， 管 理 
留言 板 员 可 随时 回复 删除 相关 主题 ， 是 一 套 人 性 竺 500/ 个 
化 的 沟通 工具 ， 有 助 于 搞 好 客 主 关系 
友情 链接 管理 员 可 随时 添加 相关 链接 王 500 人 个 
公告 王 500 人 个 
LOGO 王 200/ 个 
使 网 站 能 够 被 搜索 引擎 抓 取 ， 并 排名 靠 前 ， 3 
搜索 引擎 优化 利于 网 站 的 推广 赠送 


共计 : 域名 + 虚拟 主机 + 电子 商务 系统 + 留言 板 + 友情 链接 + 公告 版 二 如 2550， 以 后 每 年 只 需 交 
¥850〔 域 名 + 主机 》 即 可 。 
七 、 人 员 安 排 

人 员 安 排 


1 名 《和 邹 甜 甜 ? 负责 项 目的 总 体 设计 以 及 与 企业 沟通 
系统 策划 1 名 ( 刘 明 松 》 负责 网 站 的 策划 和 制作 
网 站 开发 人 员 4 名 《〔 潘 明 远 、 孙 海 、 刘 忻 南 、 梁 办 负责 系统 后 台 开发 


| 美工 |1 名 ( 曹 朋 ) | 负责 页 面 和 LOGO 设 计 
测试 人 员 负责 系统 的 后 期 调试 


八 、 后 期 维护 
在 系统 正式 使 用 的 一 年 时 间 内 ， 将 对 系统 进行 免费 维护 (添加 系统 功能 或 修改 框架 除 
外 ) ， 及 时 修改 程序 缺陷 ， 还 为 客户 提供 技术 培训 。 同 时 ， 保 证 运行 速度 和 系统 安全 。 
九 、 系 统 功能 模块 
本 系统 分 前 台 和 后 台 两 部 分 。 
国 前台 包括 
登录 及 注册 模块 : 包括 会 员 的 注册 、 登 录 和 找 回 密码 功能 。 
商品 模块 : 包括 商品 的 分 类 浏览 和 查看 。 
商品 搜索 模块 : 包括 精确 查询 和 模糊 查询 两 种 模式 。 实 现 对 商品 任意 信息 的 搜索 。 
购物 车 模块 : 帮助 会 员 完成 购物 功能 。 
在 线 支付 模块 : 支持 工行 、 招 行 等 各 个 银行 的 信用 卡 、 支 付 卡 。 
公告 栏 模块 ， 最 新 的 咨询 、 活 动 、 声 明 等 。 
友情 链接 模块 : 行业 内 网 站 之 间 的 互 换 链接 栏目 的 要 求 ， 实 现 网 站 的 免费 推广 
与 宣传 。 
留言 模块 :包括 留言 板 、 在 线 QQ 等 客户 和 企业 的 交流 平台 。 
@” 后台 包括 
图 ”商品 管理 :包括 对 商品 的 增删 改 查 等 操作 和 商品 的 类 别管 理 。 
国会 员 管理 模块 : 包括 对 会 员 的 信息 和 留言 管理 。 
图 ”订单 管理 模块 : 管理 员 可 以 对 客户 提交 的 订单 进行 编辑 、 查 看 和 处 理 。 
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26.3 系统 设计 


26.3.1 系统 目标 


根据 电子 商务 平台 的 操作 流程 ， 结 合 客户 提供 的 需求 ， 以 及 对 实际 情况 的 考察 与 分 析 ， 将 电子 商 
务 平台 的 特点 总 结 如 下 : 
页 面 设计 简洁 、 明 快 ， 突 出 重点 ， 以 吸引 用 户 目 光 为 目的 。 
前 台 操 作 流 程 清晰 ， 确 立 从 商品 浏览 、 购 物 车 、 提 交 订 单 、 查 看 订单 的 基本 流程 。 
后 台 管理 目标 明确 ， 包 括 对 用 户 、 商 品 信息 、 订 单 和 公告 等 信息 的 管理 。 
可 操作 性 高 ， 避 免 复杂 的 、 有 异议 的 链接 。 
浏览 速度 快 ， 尽 量 避 免 长 时 间 打 不 开 页 面 的 情况 发 生 。 
商品 浏览 以 实物 图 片 为 参照 ， 图 像 清 晰 ， 文 字 醒 目 。 
商品 查询 功能 ， 可 以 通过 商品 的 各 个 属性 来 搜索 。 
商品 分 类 功能 ， 为 用 户 购物 提供 导向 。 
网 站 架构 合理 ， 数 据 库 稳定 。 
易 维护 ， 并 提供 二 次 开发 支持 。 


加 图 回回 加 回回 图 回回 


26.3.2 ”系统 功能 结构 


电子 商务 平台 分 前 台 系统 和 后 台 系统 。 下 面 分 别 给 出 前 、 后 台 的 系统 功能 结构 图 。 电 子 商务 前 台 
系统 功能 结构 图 如 图 26.1 所 示 。 


电子 商务 前 合 采 统 功能 结构 图 
最 | | 推 | | 热 | | 高 | | 查 | | 用 | | 用 | | 购 | | 订 | | 友 | | 博 | | 找 
新 | | 着 | | 门 | | 品 | | 找 | | 户 | | 疡 | | 物 | | 单 | | 情 | | 城 | 上 回 
商 | | 商 | | 商 | | 分 | | 商 | | 注 | | 登 | | 流 | | 查 | | 链 | | 公 | | 密 
品 品 品 类 品 册 录 程 询 接 告 码 
查 图 购 查 | | 修 查 
看 | | 多 | | 天 看 | | 改 | | 看 | | 广 
商 | | 物 | | 商 信 | | 信 销 
和 物 
品 | | 车 品 息 | | 息 党 


图 26.1 电子 商务 前 台 系 统 功能 结构 图 
电子 商务 后 台 系 统 功 能 结构 图 如 图 26.2 所 示 。 


PHP 开发 实战 宝典 


[电子 商务 后 台 系 统 功能 结构 图 
I 


图 262 电子 商务 后 台 系统 功能 结构 图 
26.3.3 ”系统 流程 图 


为 了 便于 开发 人 员 了 解 系统 各 功能 模块 之 间 的 联系 及 完整 的 购物 流程 ， 下 面 给 出 系统 的 购物 流程 
图 ， 如 图 26.3 所 示 。 


图 26.3 系统 流程 图 
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26.4 系统 开发 环境 


在 开发 电子 商务 平台 时 ， 该 项 目 应 用 到 的 软件 如 下 。 
加 ”服务 器 端 
> 操作 系统 : Windows 2003 Server/Linux (推荐 ) 。 
服务 器 : Apache 2.2.3。 
PHP 软件 : PHP 5.1.6。 
数据 库 : MySQL 5.0.24。 
MySQL 图 形 化 管理 软件 : phpMyAdmin-2.9.0.2。 
ADODB: ADODB 5.0。 
Smarty 模板 : Smarty-2.6.19。 
开发 工具 : Dreamweaver 8。 
浏览 器 : 正 6.0 及 以 上 版 本 。 
分 辨 率 : 最 佳 效 果 1024X768 像素 。 
回 客户 端 
> 浏览 器 : 推荐 正 6.0 及 以 上 版 本 。 
> ”分辨 率 : 最 佳 效 果 1024X768 像素 。 


Vvvvyvyvyv 


vy 


26.5 数据库 与 数据 表 的 设计 


铬 m 视频 讲解 ， 光盘 \TMNVideo\26\ 数 据 库 与 数据 表 的 设计 .exe 
无 论 是 什么 系统 软件 ， 其 最 根本 的 功能 就 是 对 数据 的 操作 与 使 有 用。 所以， 一定 要 先 做 好 数据 的 分 
析 、 设 计 与 实现 ， 才 能 更 好 地 完成 对 应 的 功能 模块 。 


26.5.1 数据库 分 析 


根据 需求 分 析 和 系统 的 功能 结构 图 , 找 出 需要 保存 的 信息 数据 (也 可 以 理解 为 现实 世界 中 的 实体 )， 
并 将 其 转化 为 原始 数据 (属性 类 型 形式 。 这 种 描述 现实 世界 的 概念 模型 ， 可 以 使 用 E-R 图 来 表示 ， 
也 就 是 实体 -联系 图 。 最 后 将 E-R 图 转换 为 关系 数据 库 。 这 里 重点 介绍 几 个 E-R 图 。 

1. 会 员 信息 实体 

会 员 信息 实体 包括 编号 、 用 户 名 、 密 码 、E-mail、 身 份 证 号 、 联 系 电话 、QQ 号 、 密 码 提示 、 密 码 
答案 、 邮 编 、 注 册 时 间 、 真 实 姓名 等 属性 。 会 员 信息 实体 E-R 图 如 图 26.4 所 示 。 

2. 商品 信息 实体 

商品 信息 实体 包括 编号 、 名 称 、 上 市 时 间 、 添 加 时 间 、 型 号 、 图 片 、 库 存 、 销 售 、 商 品类 型 、 会 
员 价 、 市 场 价 、 是 否 打折 等 属性 。 商 品 信息 实体 E-R 图 如 图 26.5 所 示 。 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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实体 的 E-R 图 如 图 26.6 所 示 。 


图 26.6 商品 订单 E-R 


除了 上 面 介绍 的 3 个 E-R 图 ， 还 有 公告 实体 、 管 理 员 实体 、 类 型 实体 、 友 情 链接 实体 ， 限 于 篇 幅 ， 


这 里 不 再 资 述 。 


26.5.2 ”创建 数据 库 和 数据 表 


系统 E-R 图 设计 完成 后 ， 接 下 来 根据 E-R 图 来 创建 数据 库 和 数据 表 。 关 于 数据 库 和 数据 表 的 创建 
可 参考 第 17 章 MySQL 数据 库 基 本 操作 ， 这 里 不 再 歼 述 。 首 先 看 一 下 电子 商务 平台 都 使 用 了 哪些 数据 


表 ， 如 图 26.7 所 示 。 


下 面 来 看 各 个 数据 表 的 结构 和 字段 说 明 。 padmin Www 
回 tb_admin (管理 员 信息 表 ) ee MY 


tb_comme MISAM 


管理 员 信息 表 主 要 用 于 存储 管理 员 的 信息 。 该 数据 表 结 构 如 |e ws 


thlinks WViSAM 


9b2s12_chinese-cl 
9b2312_chinese-l 
9b2312_chineae-ci 
gba312.chinese.cl 
9b2312.chinese-ci 


图 服务 器 localhost ; 怕 救 据 库 db_database26 
表 关于 整理 说 明 


他 理 R 息 表 
商 只 表 
商品 信息 表 
向 果 单 表 
世情 久 反 表 
商品 证 兴 表 
公告 信息 家 
会 员 信 自 表 


图 26.8 所 示 。 tb-opinion MyISAM gb2312.chinesect 
tb-public MISAM 。 9b2312_chinese_cl 
回 tb_class〔 商 品类 型 表 ) tbaser ISM 9b2312.chinese.cl 
商品 类 型 列表 主要 用 于 添加 商品 的 类 别 , 可 以 设 定 多 个 子 类 图 26.7 电子 商务 数据 表 
别 ， 目 前 最 多 只 能 到 二 级 子 类 别 。 该 数据 表 结 构 如 图 26.9 所 示 。 
加 ocalhoc ， 局 米 交 订 db_oataDasea6 》 加 家 th admin 加 locaihost ， 司 禾 思 诛 db_database26 》 国家 th_class 
BE 天 菇 性 Null 要 变 各 外 9] EP 吉本 性 Null 加 站 
nt) 百 uto-increment 。 和夫 号 a my 于 


mame varchar(50) gb2312-chinese-ci 于 基本 R 了 号 name varcnar2D) gb2312_chinese_ci 天 
Pwd Yarchart2D) gb2312 chinesecl 可 和 于 名 入 内 level irth) 可 


图 26.8 管理 员 信息 表 结 构 图 26.9 商品 类 型 表 结构 


回 tb_commo《〔〈 商 品 信息 表 ) 


商品 信息 表 主 要 用 于 存储 关于 商品 的 相关 信息 。 该 数据 表 结 构 如 图 26.10 所 示 。 


auto_Incramert 。 自明 S 
B23 
i 
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回 tb form (商品 订单 表 ) 
商品 订单 表 主 要 用 于 存储 商品 的 订单 信息 。 该 数据 表 结 构 如 图 26.11 所 示 。 


加 服务 器 : localhost ， 悍 数据 库 - db_database26 ， 回 表 - tb_commn 加 服务 鼻 - localhost 图 数据 库 - db_database26 》 国志: tb_form 
守 民 ”关于 EE DOE 训 明 #8 关于 到 可 是 ml 2 
uy intq) 要 StD_increment ”自动 护 号 EL Tree 否 auro_incremenc 。 自动 这 号 
name 。 varcharGo) gb2a12.chinesed 可 而 只 varchati25) gh2sl2.chinese-d 如 He 
varchar(2n0) gb2312-chinese cl 可 两 品 国 片 varcharloD) gc2312.chnese- 看 i 
mediumtext gbaa12.chinesa-cl 理 而 achatso) ge2312.chinesed 百 和 
diate 下 Fe vartharloo) ge2312-chinese-d 可 市 28 
varcher6a) -gbaa12.chinese.d 玫 两 和 RE 站 于 RE ES 浊 
varcharsa) gz312.chnasa- 百 Fr fold varchalso) ge2312.chinese.d 到 i 
varchart50) ghzs12.chinese dl 否 i pp 
VHBo) | 9b2212.ehnaad | 于 RE hastzzhnaaal | 百 A 
RE i 站 a ge2312.chinese_d 百 收 折 地 扯 
轨 油 训 FE bzalzchrese-q 百 太夫 
re Moar 百 而 声 从 入 于 2312-chineseq 。 百 
e fox 要 会 员 价格 gb2312_chinese -5 El 村 豆 万 式 
ir 4 3 打折 李 gb2312-chi rese- 吕 百 洋 代 5 式 
ie 可 1 aE 本 可 om 
ia 本 0 i no 日 Te 


图 26.10 商品 信息 表 结 构 图 26.11 商品 订单 表 结 构 


回 tb_public〈 商 品 公告 表 ) 

商品 公告 表 主要 用 于 展示 网 站 的 最 新 活动 和 最 新 消息 ， 包 括 公告 时 间 、 公 告 标题 和 公告 内 容 。 该 
数据 表 结 构 如 图 26.12 所 示 。 

加 tb_user (用户 信息 表 ) 

用 户 信息 表 主要 用 于 存储 用 户 的 基础 信息 。 该 数据 表 结 构 如 图 26.13 所 示 。 


胃 里 各 如 :localhost 各 数据 库 : db_database26 ， 回 表 ; tb_user 
字 慨 并 于 本 上 Null 默 。 瑚 让 说 明 
人 世 队 
地 ind) 否 aulO_Incremenr 。 自动 闹 号 
Varchar(50] 9b2312-chinese- 查 会 员 名 称 
Varcher(50] ge2312.chinese_dl 可 密友 
varcharGol -gb2312.chinese.d 可 入 
varcher(s0] = geal2.chinese.c 要 和 
ar 要 0 消费 名 
‘varchar(50) 。 go2312-chinase_o 二 真实 好 名 
Varcharfzoj ”9b2312-chinese-ol 可 身价 证 号 
Varchar(20) gb2312-chinese-o 本 各 风 电话 
Varchacol gbz312chinese.0 再 四 
varchartz5) ”gh2312-chinese-0 要 our 
国 服务 全: Iocalhost ， 电 数据库 - db_database26 ， 蕊 表 -th_public Varchar(lal 。 gb2312_chinese_o 要 加 
字 险 类 双开 时 ml 要。 wo varcharlal 。 gb2312.chinese.d 可 C2] 
FP 可 ro neement Bimae er I 并 
varchats0) gh2312.chinese.ci 于 全 Li 和 这 出 时 间 
madlumtaxt gb2312_chinase_cl 查 人 AN rl) 圭 0 是 理 所 结 
date 天 em varchar(a00) go2312_chinase_o 本 的 国标 信息 


图 26.12 商品 公告 表 结构 图 26.13 用 户 信息 表 结构 
此 外 还 有 友情 链接 表 和 商品 评论 表 ， 限 于 篇 幅 ， 这 里 不 再 介绍 ， 读 者 可 参考 本 书 配套 光盘 中 的 数 


据 库 文件 。 
26.6 ”搭建 系统 框架 


编写 代码 之 前 ， 可 以 把 系统 中 可 能 用 到 的 文件 夹 先 创建 出 来 (如 创建 一 个 名 为 images 的 文件 夹 ， 
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用 于 保存 程序 中 所 使 用 的 图 片 ) ， 这 样 不 但 可 以 方便 以 后 的 开发 工作 ， 也 可 以 规范 系统 的 整体 架构 。 


因为 本 项 目 使 用 的 是 Smarty+ADODB 技术 , 所 以 目录 较 多 。 下 面 来 看 本 系统 的 目录 结构 (到 三 级 目录 )， 
如 图 26.14 所 示 。 


电子 商城 系统 目录 


HO topletes sarty 模 板 文件 
HO tpletes_e Smart 文件 


图 26.14 系统 目录 结构 图 
26.7 公共 文件 设计 


铬 m 视频 讲解 ， 光盘 \TMNVideo\26\ 公 共 文件 设计 .exe 

公共 文件 就 是 将 多 个 页 面 都 可 能 使 用 到 的 代码 写成 单独 的 文件 , 在 使 用 时 只 要 用 include 或 require 
将 文件 包含 进来 即 可 。 如 本 系统 中 的 数据 库 连接 文件 、Smarty 配置 文件 、CSS 样式 文件 、JS 脚本 文件 
等 。 以 前 台 系统 为 例 ， 下 面 给 出 主要 的 公共 文件 。 后 台 的 公共 文件 与 前 台大 同 小 异 。 


26.7.1 数据 库 连接 文件 


数据 库 连接 文件 ， 就 是 在 读 取 或 存储 数据 时 连接 数据 库 所 使 用 到 的 函数 。conn.php 文件 代码 如 下 。 


<?php 
include_once ("adodb5/adodb.inc.php"): 


// 载 入 ADODB 类 库 
S$conn = ADONewConnection(mysql)): // 连 接 MySQL 
Sconn->PConnect('localhost','root','root',db_database26") or die(connection error):  //db_database26 库 
$conn->Execute('set names gb2312'): // 设 置 编码 
$ADODB FETCH MODE = ADODB FETCH BOTH: 1/ 设置 结果 集 存储 方式 
Ye 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


} 
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Ik:visited { 


} 


text-decoration: none:; 
color: #350407:; 


Ik:hover { 


} 


text-decoration: none: 


.lk:active { 


二 


text-decoration: none: 
color: #CCCCFF: 


表格 首 行 样式 -> 


first { 


<!-- 


background-color: #FFC4C4: 
border-bottom-width: 1px: 
border-bottom-style: solid: 
border-bottom-color: #FFC4C4:; 
color: #000000; 

font-size: 14px:; 

font-weight: bold; 


左 侧 表格 样式 --> 


Jeft{ 


<!-- 


border-left-width: 1px; 
border-right-width: 1px: 
border-bottom-width: 1px: 
border-left-style: solid; 
border-right-style: solid: 
border-bottom-style: solid; 
border-left-color: #FFC4C4:; 
border-right-color: #FFC4C4: 
border-bottom-color: 证 FC4C4: 


中 间 表 格 样式 -> 


.Center { 


<!-- 


border-right-width: 1px: 
border-bottom-width: 1px: 
border-right-style: solid; 
border-bottom-style: solid: 
border-right-color: #EfFC4C4: 
border-bottom-color: #FFC4C4: 


右 侧 表格 样式 -> 


ight { 


border-right-width: 1px: 
border-bottom-width: 1px: 
border-right-style: solid: 
border-bottom-style: solid: 
border-right-color: #fFC4C4: 


SS9 
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border-bottom-color: #FFC4C4: 


} 
<!-。 文本 框 样式 -> 
txt { 
margin: Opx:; 
padding: Opx: 
height: 18px: 
width: 100px; 
border: 1px solid #979797; 


小 文本 样式 -> 
.Shorttxt { 

margin: Opx; 

padding: Opx; 

height: 18px: 

width:50px; 

border: 1px solid #979797; 


} 
<!-- 长 文本 样式 -> 
.langtxt { 

margin: Opx; 

padding: Opx; 

height: 18px: 

width: 200px: 

border: 1px solid #979797: 


} 
<!-- 文本 域 样 式 -> 
.areatxt { 

margin: OpX: 

padding: Opx: 

border:1px solid #979797: 


} 

<!-- 按钮 样式 --> 

bm { 
font-size: 12px: 
color: #350407; 
background-color: #FFFFFF:; 


margin: Opx: 

padding: Opx: 

height: 15px: 

width: SOpx: 

border: 1px solid #000000: 
} 
<!-- 整个 表格 样式 -> 
-all{ 

border: 1px solid #979797:; 


本 系统 的 公共 文件 介绍 完毕 ， 下 面 讲 解 本 系统 中 重点 模块 的 实现 方法 。 
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26.8 前 台 首页 设计 


铭 m 视频 讲解 ， 光盘 \TMNVideo\26\ 前 台 首页 设计 .exe 

前 台 首页 一 般 没 有 多 少 实质 性 的 技术 ， 主 要 是 加 载 一 些 功能 模块 ， 如 登录 模块 、 导 航 栏 模块 、 公 
告 栏 模块 等 ， 使 浏览 者 能 够 了 解 网 站 内 容 和 特点 。 首 页 的 重要 之 处 是 合理 地 对 页 面 进 行 布局 ， 既 要 尽 
可 能 地 将 重点 模块 显示 出 来 ， 同 时 又 不 能 因为 页 面 凌乱 无 序 ， 而 让 浏览 者 无 所 适 从 、 产 生 反感 。 本 系 
统 前 台 首 页 index.php 的 运行 结果 如 图 26.15 所 示 。 


26.15 前台 首页 运行 结果 


本 页 面 使 用 的 是 表格 布局 ， 除 了 商品 模块 和 登录 模块 外 ， 其 他 模块 都 是 固定 不 变 的 。 登 录 模 块 在 
会 员 成 功 登录 后 ， 将 显示 会 员 信息 模块 ;而 商品 模块 的 位 置 ， 则 根据 不 同 的 链接 而 显示 不 同 的 页 面 。 
index.php 页 面 的 核心 代码 如 下 。 


<2php 
session_start0:/* 开启 Session */ 
?> 
<table width="850" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<!-- 载 入 导航 栏 模块 。--> 
<td colspan="2"><?php include_once 'top.php': ?></td> 
</u> 
<tr><td width="216" align="left" valign="top"> 
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<?php 
睛 ” 载 入 登录 模块 、 公 告 栏 模块 和 友情 链接 模块 。*/ 
include_ once login.php': 
include_ once 'public.php': 
include_ once "links.php'; 
x 
</td> 
<td width="634" height="848" align="center" valign="top"> 
<?php 
片 ” 载 入 查询 模块 */ 
include_once 'search_php': 
?> 


<?php 
必 ”根据 不 同 的 page 值 ， 载 入 不 同 的 模块 */ 
Switch($_ GET["page"]){ 

Case "™": 


include_once ‘nominate.php'; // 载 入 商品 模块 
include_once 'newhot.php'; break: 
case "hyzx":include_once "memberphp": break: // 载 入 会 员 中 心 模块 
case 'allpub': include_once ‘allpub.php'; break: // 显 示 公 告 栏 模 块 
case mom' include_once 'allnom.php'; break: // 显 示 推荐 商品 模块 
case mew' include_once 'allnew.php'; break: // 显 示 最 新 商品 模块 
case ‘hot': include_once 'allhot php': break: // 显 示 热 门 商品 模块 
case 'shopcar': include_once 'myshopcar.php' break:: // 显 示 购 物 车 模块 
case 'settle': include_once 'settle.php'; break: // 收 银 台 模块 
default: 
include_once mominate .php': // 默 认 显示 商品 模块 
include_once 'newhot.php'; 
} 
?></td></tr> 
</table> 


<table width="850" border="0" cellspacing="0" cellpadding="0"> 
<tr><td><?php include_once ‘buttom.html'; ?></td></tr> // 底 部 导航 栏 模 块 
</table> 


下 面 详细 讲解 其 中 几 个 重点 模块 的 实现 过 程 。 只 要 将 这 几 个 模块 所 使 用 的 技术 和 方法 掌握 好 ， 其 
他 模块 的 实现 也 就 迎刃而解 了 。 


[加 说 明 : 本 系统 的 功能 较 多 ， 结 构 比 较 复杂 ， 对 于 初学 者 来 说 学 起 来 可 能 会 比较 困难 。 所 以 ， 本 书 
将 系统 中 的 各 个 功能 模块 所 涉及 的 文件 (PHP、TPL、CSS、JS 等 ) 尽 可 能 都 单独 实现 。 读 
者 在 学 习 其 中 某 个 模块 时 ， 可 以 将 相关 的 文件 统一 放 到 一 个 目录 下 单独 测试 。 


26.9 登录 模块 设计 


用 户 登 录 模 块 是 会 员 进 入 的 窗口 。 匿 名 用 户 虽然 也 可 以 访问 本 网 站 ， 但 只 能 进行 浏览 、 查 询 等 简 
单 操作 ， 而 会 员 则 可 以 购买 商品 ， 并 且 能 享受 商品 折扣 。 登 录 模块 包括 用 户 注册 、 用 户 登录 和 找 回 密 
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码 3 部 分 。 
26.9.1 用 户 注册 


镶 m 视频 讲解 ， 光盘 \TM\VideoW26\ 用 户 注册 .exe 

用 户 注 册 通 过 一 个 form 表单 ， 将 新 用 户 填 写 的 完整 、 合 理 、 正 确 的 信息 保存 到 数据 库 中 。 如 果 用 
户 填写 的 信息 不 正确 或 者 不 符合 要 求 ， 则 直接 显示 错误 原因 ， 以 便 用 户 修改 。 本 系统 的 登录 模块 使 用 
目前 比较 流行 的 Ajax 技术 来 验证 用 户 输入 的 数据 ， 应 用 GD2 函数 库 生 成 验证 码 。 本 页 面 的 运行 结果 
如 图 26.16 所 示 。 


wR， 站] 。 国 遇 天下 二 类 X 工 有 
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图 26.16 注册 模块 页 面 


由 于 篇 幅 的 限制 ， 这 里 只 给 出 有 代表 性 的 程序 块 ， 即 用 户 名 验证 和 验证 码 验 证 这 两 部 分 ， 而 其 他 
信息 的 验证 方法 在 这 两 个 程序 块 中 都 使 用 到 了 。 

1. 创建 模板 

首先 创建 模板 文件 。 该 模板 主要 包括 注册 表单 和 div 标签 。 其 中 ，div 标签 是 用 来 提示 录入 的 回馈 
信息 。 模 板 文件 register.tpl 的 核心 代码 如 下 。 


<!-- 载 入 xmlhttp.js 文件 和 check.js 文 件 -> 
<script language="javascript" src="js/createxmlhttp.js"></script> 
‘<script language="javascript" src="js/check.js"></script> 
<!-- 注册 表单 部 分 -> 
<form id="register" name="register" action="reg_chk.php" method="post" onSubmit="return chkinput(this)"> 
<!--” 用户 名 验证 部 分 --> 
<t> 
<td width="81" height="25"><div align="right"> 用 户 名 : </div></td> 
<td height="25" colspan="3">&nbsp: 
<!-- 文本 框 ， 将 会 触发 onBlur 事件 ， 调 用 chkname0 方 法 --> 
<input id = " name " name =" name " type = " text " onBlur = " javascript:chkname( register ) " /> 
<!--” 隐藏 域 ， 默 认 值 为 “not” 即 不 允许 注册 --> 
<input id = " ¢ name " name =" ¢ anme " type = " hidden " value = " not " >&nbsp:<font color = " red "> 
*</font></td> 
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<!-- div 卷 标 用 于 显示 对 用 户 名 的 检测 结果 -> 
<td height="25"><div id="name1"><font color="#999999"> 请 输入 用 户 名 </font></div></td> 
</t> 
<tr> 
<td height="25" colspan="2">&nbsp: 
<input type="submit" value=" 提 交 "/> 
&nbsp:&nbsp: 
<input type="reset" value=" 重 写 " /></td> 
<td height="25" colspan="3"><div style="color:#EF0000"> 带 “*” 号 的 为 必 填 项 </div></td> 
</t> 
</form> 
</table> 


这 里 包含 了 两 个 js 文件 : createxmlhttp.js 和 check.js。 其 中 ， 对 createxmlhttp.js 文件 在 26.7 节 中 己 
作 了 详细 的 讲解 ， 而 checkjs 文件 用 于 实现 对 用 户 名 和 验证 码 的 验证 过 程 。 

2. 实现 用 户 名 验证 

用 户 名 验证 包括 两 个 部 分 。 第 一 部 分 是 当 用 户 输入 名 称 后 ， 焦 点 离开 当前 文本 框 时 所 触发 的 ， 触 
发 的 函数 为 chkname(form)。 代 码 如 下 。 


谨 ”form 为 传 入 的 表单 名 称 ， 本 段 代 码 为 register 表单 */ 
function chkname(form){ 
请 ”如果 name 文本 域 的 信息 为 空 ， 名 为 namel 的 div 标签 显示 如 下 信息 */ 


namel.innerHTML="<font color=#FF0000> 请 输入 用 户 名 ! </font>"; 
}else{ 
让 ”否则 获取 文本 域 的 值 */ 
Varuser = form.name.value; 
证” 生成 url 链接， 将 user 的 值 传 到 chkname.php 页 进行 判断 */ 
Var url = "chkname.php?user="+user; 
必 使 用 XMLHttpRequest 技术 运行 页 面 */ 
xmlhttp.open("GET"urltrue): 
Xmlhttp.onreadystatechange = functionO{ 
if(xmlhttp.readyState 一 4){ 
上 ”根据 不 同 的 返回 值 ， 在 div 标签 中 输出 不 同 信息 */ 
Var msg = xmlhttp.responseText: 


这 msg =—'2){ 
namel.innerHTML="<font color=#FF0000> 用 户 名 被 占用 ! </font>": 
Tetum false: 

jelse if(msg —'1){ 
namel .inner] 一 "<font color=green> 巷 喜 您 ， 可 以 注册 !</font>"; 


证 ”如 果 用 户 名 正确 ， 则 将 隐藏 域 的 值 改 为 “yes” */ 
form.c name.value = "yes": 

jelse{ 
namel.inneIHTML="<font color=green> 未 知 错误 </font>": 


xmlhttp.send(null): 
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} 

这 个 函数 调用 了 chkname.php 页 ， 该 页 在 会 员 登 录 时 也 会 被 调用 ， 所 以 这 里 分 两 种 情况 ， 有 密码 
和 无 密码 。 无 密码 为 注册 验证 ， 当 没有 返回 结果 时 ， 说 明 该 用 户 名 可 用 ; 有 密码 为 登录 验证 ， 和 无 密码 
相反 ， 只 有 查询 记录 存在 时 ， 才 允许 登录 ， 并 将 用 户 名 和 用 户 DD 存储 到 Session 中 。 该 页 面 代码 如 下 : 


<2?php 

session start() /开启 Session 支持 
include_once "conn/conn.php"; // 加 载 数 据 库 连 接 文 件 
Sreback = '0': /声明 返回 变数 ， 初 值 为 “0” 
$sql = "select * from tb_user Where name=".$ GET[user]."": /生成 SQL 语句 


证 ”下面 的 SQL 语句 加 上 了 对 密码 的 比较 ， 这 是 用 来 验证 登录 的 ， 因 为 登录 验证 使 用 的 也 是 本 页 面 */ 
Spassword =$_GET[password']: 
这 !empty($password)){ 

$sql =" and password = ".md5($password).™™": /如果 密 码 不 为 空 ， 说 明 是 登录 验证 


} 
上 # ”执行 SQL 语 名 */ 
Srst = $conn->Execute($sql) or die('execute error’); // 根 据 name 字段 查询 数据 库 
这 $rst->RecordCount0 =— 1){ // 判 断 name 是 否 被 使 用 
作 登录 所 用 */ 
if($rst->fields['isfreeze'] != 0){ 
Sreback = "3"; 
}else{ 
$_ SESSION[member] = Srst->fields['name’]: 
$_SESSION['id'] = S$rst->fields['id']: 
Sreback = "2'; 
} 
}else{ 
Sreback = "1"; 
} 
echo Sreback: 
?> 


上 面 的 过 程 是 第 一 次 对 用 户 名 进行 判断 。 当 用 户 无 视 警告 信息 单 击 “提交 ”按钮 时 , 就 会 触发 <form> 
表单 中 的 onsubmit 事件 ， 该 事件 触发 chkinput0 函 数 ， 此 函数 通过 隐藏 域 来 判断 该 注册 名 称 是 否 合法 。 
程序 代码 如 下 : 


function chkinput(form){ 

if(form.name.value—""){ /判断 用 户 名 称 文本 域 是 否 为 空 
form.name.focus(): 
Tetum false: 

if(form.c_name.value — "not"){ /判断 隐藏 域 c_ name 的 值 是否 为 not 
form.name.select(): // 如 果 是 not， 说 明 该 名 称 未 通过 验证 ， 返 回 false 
Tetum false: 

} 
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运行 结果 如 图 26.17 所 示 。 
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图 26.17 用 户 名 验证 过 程 


3. 验证 码 验 证 
验证 码 验证 ， 先 来 看 register.tpl 模板 是 如 何 显示 验证 码 的 ， 代 码 如 下 : 
<!-- ”验证 码 验证 部 分 --> 
<t> 
<td height="25"><div align="right"> 验 证 码 : </div></td> 
<td width="65" height="25">&nbsp; 
<!-- ”验证 码 输入 框 ， 会 触发 onBlur 事件 --> 
<input id="yzm" type="text" name="yzm" size="8" onBlur="javascript:chkyzm(register)" /> 
<!-- ”隐藏 域 ， 保 存 验证 码 -> 
<input name="yzm2" type="hidden" value="" /></td> 
<!-- ”验证 码 显示 区 --> 
<td width="65" align="center" valign="middle"><script>yzm(register)</script></td> 
<!-- ”在 看 不 清 验 证 码 的 时 候 更 换 验证 图 片 。--> 
<td width="51"><a href="javascript:code("> 看 不 清 </a></td> 
<!-- div 标签 ， 用 于 显示 验证 信息 --> 


<td height="25"><div id="yzm1"><font color="#999999"> 输 入 验证 码 </font></div></td> 
</t> 


通过 模板 页 代码 可 以 看 到 ， 模 板 页 通过 调用 yzm() 函 数 来 显示 验证 码 。yzm0 函 数 的 代码 如 下 : 


function yzm(form){ 
var num1=Math.round(Math.random()*10000000): // 产 生 随 机 数 
var num=num1.toString().substr(0,4); /获取 前 4 位 数 
document write("<img name=codeimg src='yzm.php?num="+num+"> // 输 出 图 片 形式 的 验证 码 
form yzm?2.value=num:; // 将 验证 码 保存 到 隐藏 域 中 
} 


在 yzm0 函 数 内 , 使 用 Math.round0 函 数 生成 随机 码 , 并 截取 前 4 位 , 然后 将 验证 码 提交 给 yzm.php 
页 进行 转换 ， 并 显示 由 yzm.php 生成 的 png 图 片 。 最 后 将 验证 码 存储 到 名 字 是 yzm2 的 隐藏 域 中 , 用 作 
验证 码 检查 。yzm.php 页 面 使 用 的 是 GD2 函数 库 。 生 成 验证 码 的 代码 如 下 : 


<?php 

srand((double)microtimeO*1000000): // 生 成 随机 数 
Sim=imagecreate(42,16): // 创 建 画 布 
S$black=imagecolorallocate($im.0,0.0): // 定 义 背 景 
Swhite=imagecolorallocate($im.255.255.255): /定义 背景 
Sgray=imagecolorallocate($im.200.200.200): // 定 义 背 景 
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Spassword = md5($_ POST[pwdlT): // 使 用 MDS5 给 密码 加 密 

Squestion =$_ POST['question ]:; 

Sanswer = $ POST['answer]: 

Srealname = $_ POST[realname']: 

Scard = $_POST['card']: 

Stel =$_POSTh'tel]: 

$phone = $_POST['phone']: 

$Email = $_ POST['email]: 

$QQ=$ POST['qq]: 

$code = $_POST['code']; 

$address = $_ POST['address']: 

Saddtime = Sconn->DBDate(time0O): // 使 用 DBDate0 函 数 生成 当前 时 间 
/闪闪 闪闪 闪闪 次 闪闪 诡 兴 闪光 实 闪 诡 闪 闪闪 实 闪 交 / 

上 请 生成 SQL 语 句 */ 

$sql = "insert into tb_user ( name, password, question,answer, realname .card, tel, phone, Email, QQ, code, address, 


addtime,isfreeze,shopping)" ; 


$sql = " values (‘$name', '$password', '$question', '$answer', '$realname', '$card', '$tel', '$phone', '$SEmail', '$QQ', 


‘$code', ‘$address', $addtime,'0',")"; 


族 执行 SQL 语句 */ 
S$rst = $conn->execute($sq]); 
店 ” 判 断 添加 是 否 成 功 */ 
if($rst 一 false){ 
echo '<script>alert(\ 添 加 失败 \):history.back:</script>': 
}else{ 
店 ” 如 果 成 功 ， 则 将 用 户 ID 和 用 户 名 称 存 到 Session 中 */ 
$_SESSION[member] = $name; 
$_SESSION['id'] = $conn->Insert_ID(): /Insert_ ID0 函 数 获取 新 增 数据 的 ID 号 
echo "<script>top.opener.location.reload0:alert( 注 册 成 功 ):window.closeO:</script>"; 
} 


5.， 加载 模板 
因为 本 系统 使 用 了 Smarty， 所 以 还 需要 创建 一 个 PHP 页 来 加 载 模板 文件 。register.php 页 面 的 内 容 


非常 简单 ， 代 码 如 下 : 


<?php 


include_once 'config.php'; // 载 入 config.php 文 件 
Ssmarty->assign('"title',' 新 用 户 注 册 "): /设置 title 
$smarty->display(Tregister.tpl): /显示 register.tpl 


6. 创建 链接 
以 上 就 是 用 户 注册 模块 的 核心 代码 。 当 测试 没有 问题 后 ， 最 后 创建 一 个 “注册 ” 超 链 接 。 当 用 户 


单 击 前 台 的 鲁 了 辐 按 钮 时 ， 系 统 会 调用 js 的 onclick 事件 ， 弹 出 注册 窗口 。 代 码 如 下 : 
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这 里 使 用 到 的 js 文件 为 js/loginjs。 调 用 的 函数 为 reg0， 该 函数 代码 如 下 : 
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function regO{ 
window.open("registerphp", ”blank". "width=500.height=450".false): /弹出 新 窗口 
} 


26.9.2 用户 登录 


铬 m 视频 讲解 :光盘 \TM\VideoW26\ 用 户 登录 .exe 
除了 在 注册 时 可 以 直接 登录 ， 其 他 情况 下 用 户 可 以 通过 登录 区 进行 登 
录 操 作 。 用 户 登 录 模 块 的 运行 结果 如 图 26.18 所 示 。 各 一 


1， 信 息 验证 eg 
用 户 登 录 同 样 使 用 的 是 Ajax 验证 方法 。 首 先 创建 页 面 模板 文件 es 
login.tpl， 该 文件 主要 包含 一 个 登录 表单 。 登 录 表单 各 元 素 的 属性 值 及 超 
链接 说 明 如 表 26.1 所 示 。 26.18 ”用 户 登录 页 面 
表 26.1 登录 表单 各 元 素 属性 说 明 
元 素 名 称 元 素 属 性 元 素 说 明 
i id="login "name="login" method="post " action ="#" | 登录 表单 可 以 触发 onsubmit 事 件 来 
人 onsubmit =" return lg( this ) " 调用 lg0 函 数 ， 表 单 名 称 为 login 
text id="name" name="name" type="text" 用 户 名 文本 框 


text id="password" name="password" type="password" 密码 文本 框 


submit id="enter" name="enter" type="submit" 登录 按钮 


<a> 看 不 清 </a> onclick="javascript:code(login)" style=" cursor:hand" 更 换 验 证 码 图 片 
hidden name="check2" type="hidden" value="" 保存 验证 码 的 隐藏 域 
<a> 用 户 注 册 </a> | id="login" href="#" onclick="regO” 注册 页 面 超 链接 
<a> 找 回 密码 </a> | id="login" href="#" onclick="foundO" 找 回 密码 超 链接 


通过 表 26.1 可 知 ， 当 单 击 submit 按钮 时 ， 系 统 将 调用 lg0 函 数 。lg0 函 数 包含 在 jsllogin.js 脚本 文 
件 内 ， 该 函数 代码 如 下 : 


function lg(form){ 
刻 ” 检 验 用 户 名 所 
if(form.name.value—""){ 
alert(' 请 输入 用 户 名 ): 
form.name.focus(): 
Tetum false: 


} 

族 ”检验 密码 */ 

这 form.password.value 一 "" || form.password.value.length < 6){ 
alert(' 请 输入 正确 密码 ): 
form.password.focus(); 
Tetum false: 


} 
族 ” 检 验 验 证 码 。 */ 
这 form.check.value — ""){ 


PHP 开发 实战 宝典 


alert(' 请 输入 验证 码 '); 
form.check.focus(): 
Tetum false; 
, 
让 ”比较 验证 码 。 */ 
if(form.check.value != form.check2.value){ 
form.check.selectO: 
code(form); 
Tetum false; 


} 
店 ”根据 输入 的 用 户 名 和 密码 生成 ml */ 
Var user = form.name.value; 
Var password = form.password.value; 
Var url = "chkname.php?user="+user+"&password="+password:; 
启 ”使 用 xmlhttp 对 象 来 返回 验证 结果 */ 
xmlhttp.open("GET",url,true): 
xmlhttp.onreadystatechange = functionO{ 
if(xmlhttp.readyState 一 4){ 
var msg=Xmlhttp.TesponseText: 
上 # ”如 果 返 回 值 不 等 于 2， 说 明 用 户 名 或 密码 错误 3/ 
这 msg —'1){ 
alert(' 用 户 名 或 密码 错误 !!"): 
form.password.select(); 
form.check.value ="; 
code(form): 
return false; 
}if(msg —"3"){ 
alert(" 该 用 户 被 冻结 ， 请 联系 管理 员 "); 
return false; 
} else{ ”入 ”如果 成 功 ， 重 新 刷新 本 页 */ 
alert( 欢 迎 光 临 ?:; 


location.reload(): 


} 


} 
xmilhttp.send(null): 
return false: 
用 户 名 和 密码 是 在 chkname.php 页 面 中 被 验证 的 。chkname.php 的 相关 内 容 在 26.9.1 节 中 已 经 介绍 
过 ， 这 里 不 再 效 述 。 
2. 用 户 信息 
用 户 登 录 成 功 后 ， 在 原 登 录 框 位 置 将 显示 用 户 信息 模块 。 用 户 可 以 通过 “会 员 中心 ” 超 链接 对 自 
己 的 信息 进行 修改 ， 也 可 以 单 击 “ 查 看 购物 车 ” 超 链接 查看 购物 车 商品 ， 用 户 还 可 以 通过 单 击 “ 安 全 
离开 ” 超 链接 离开 。 关 于 会 员 信息 模块 ， 将 在 26.10 节 中 进行 讲解 。 用 户 信 息 模 块 的 主要 代码 如 下 : 


<!--” 显示 当前 登录 用 户 名 --> 
欢迎 您 : {Smember} 
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1. 创建 模板 文件 
虽然 找 回 密码 需要 4 个 步骤 ， 但 实际 上 每 个 步骤 使 用 的 都 是 相同 的 模板 文件 和 js 文件 ， 只 是 被 调 


用 的 表单 和 js 函数 略 有 差别 。 这 里 根据 不 同 的 文件 分 别 进行 介绍 。 


首先 来 看 模板 文件 。 该 模板 文件 一 共 包 含 了 3 个 表单 ， 分 别 代表 了 3 个 步骤 。 下 面 是 模板 文件 的 


核心 代码 。 
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<!-- 载 入 两 个 js 脚本 文件 -> 
<script language="javascript" src="js/createxmlhttp.js"></script> 
<script language="javascript" src="js/found.js"></script> 
<!-- 第 一 个 div 标签 -> 
<div id="first"> 
<table width="200" border="0" cellspacing="0" cellpaddine="0"> 
<tr><td> 找 回 密码 </td></tr> 
<tr><td> 会 员 名 称 : </td> 
<!-- text 文 本 域 ， 用 于 输入 要 找 回 密码 的 会 员 名 称 “--> 
<td><input id="user" name="user" type="text" class="txt"></td> 
</t> 
<t><td> 
<!-- 单 击 “下 一 步 ” 按 钮 ， 能 触发 onclick 事件 来 调用 chkname0 函 数 ”-->\ 
<input id = "nextl " name = " nextl " type = " button " class = " btn " value = " 下 一 步 " onClick = " retum chkname 
(foundname ) "/></td></t> 
</form> 
</table> 
</div> 
<!-- 第 二 个 div 标签 ， 样 式 为 隐藏 --> 
<div id="second" style="display:none:"> 
<table> 
<form id="foundanswer" name="found" method="post" action="#"> 
<tr><td > 找 回 密码 </td></tr> 
<tr><td> 密 保 问 题 ，</td> 
<!-- 用 于 显示 密 保 问 题 的 div 标签 --> 
<td <div id="question"></div></td></tr> 
<tr><td> 密 保 答案 : </td> 
<!-- 文本 域 ， 用 于 填写 密 保 答案 --> 
<td ><input id="answer" name="answer" type="text" class="txt" /></td></tr> 


<tr> 
<!-- 单 击 “下 一 步 ” 按 钮 ， 用 来 触发 onclick 事件 ， 并 调用 chkanswer0 函 数 ”--> 
<td><input id = " next2 " name = " next2 " type=" button " class=" btn " value =" 下 一 步 "onClick = " return 
chkanswer( foundanswer ) "></td> 
</t> 
</form> 
</table> 
</div> 
<!-- 第 三 个 div 标签 ， 样 式 也 为 隐藏 ， 作 用 是 修改 密码 -> 
<div id='third' style="display:none:"> 
<table> 
<form id="modifypwd" name="found" method="post" action="#"> 
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<tr><td> 输入 密码 </td></tr> 
<tr><td> 输 入 密码 : </td> 
<td><input id="pwdl" name="pwd1" type="password" class="txt"></td></tr> 
<tr><td> 确 认 密 码 : </td> 
<td><input id="pwd2" name="pwd2" type="password" class="txt" /></td> 
</t> 
<tr> 
<!-- 单 击 “ 完 成 ”按钮 ， 调 用 chkpwd0 函 数 --> 
<td><input id =" mod " name =" mod " type =" button " class =" bn " value =" 完成 "onClick =" return chkpwd 
(modifypwd) "></td> 
</> 
</form> 
</table> 
</div> 


可 以 发 现 ，3 个 表单 中 ， 只 有 一 个 表单 默认 情况 下 是 显示 的 ， 其 他 则 为 隐藏 。 只 有 通过 调用 不 同 的 
js 函数 ， 才 可 以 对 其 他 表单 进行 操作 。 
2. 创建 js 脚本 文件 


found.js 脚本 文件 包含 3 个 函数 : chkname0、chkanswer0 和 chkpwd0。 其 中 chknameO 函 数 的 作 / 
是 检查 用 户 输入 的 会 员 名 称 ， 如 果 存 在 ， 则 使 用 xmlhttp 对 象 去 调用 生成 的 ml 进行 判断 。 如 果 该 用 户 
存在 ， 则 隐藏 当前 表单 ， 并 显示 下 一 个 表单 ， 最 后 输出 密 保 问题 。chknameO 函 数 的 代码 如 下 : 


function chkname(form){ 

卢 ”获取 文本 框 信息 */ 

Var User = form.user.value; 

卢 ” 如 果 为 空 ， 则 输出 提示 。 */ 

if(user —"){ 
alert( 请 输入 用 户 名 "): 
form.user.focus(); 

Tetum false: 

jelse{ 

证 ”否则 ， 生 成 url， 并 调用 xmlhttp 对 象 a 
var url = "foundpwd.php?user="+user: 
xmlhttp.open("GET",url,true); 
xmlhttp.onreadystatechange = functionO{ 
if(xmlhttp.readyState 一 4){ 

Var msg = xmlhttp.responseText: 

睛 如果 没有 结果 ， 则 提示 六 

iftmsg —'0){ 
alert( 没 有 该 用 户 ， 请 重新 查找 !"): 
form.user.select(): 

Tetum false: 

jelse{ 

让 ”否则 ， 隐 藏 当前 表单 ， 显 示 下 一 个 表单 ， 并 输出 密 保 问 题 */ 
document.getElementById('first').style.display = mone': 
document.getElementById('second').style.display = ": 
document.getElementById('question').innerHTML = msg: 
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xmlhttp.send(nulD): 


其 他 两 个 函数 也 使 用 了 XMLHttpRequest 对 象 , 实现 方法 相差 无 几 , 不 同 之 处 在 于 对 返回 值 的 处 理 。 
chkanswerO 函 数 隐 藏 当前 表单 ， 显 示 下 一 个 表单 。chkanswerO 函 数 的 代码 如 下 : 


function chkanswer(form) { 
上 # “获取 已 隐藏 表单 数据 */ 
Var User = document.getElementById(user).value: 
上 “获取 密 保 答案 */ 
Var answer = form.ansWer.Value: 
上 “表单 验证 */ 


这 answer — "){ 


jelse{ 
请 生成 mi */ 
var url = "foundpwd.php?user="+user+"&answer="+answer: 
xmlhttp.open("GET".urLtrue): 
Xmlhttp.onreadystatechange = functionO{ 
这 xmlhttp.readyState 一 4){ 
var msg = xmlhttp.responseText: 
iftmsg —'0){ 
alert( 问 题 回答 错误 ): 
form.answer.select(); 
Tetum false; 
jelse{ 
document.getElementById(second).style.display = "none': 
document.getElementById('third").style.display = "; 


} 
} 
} 
xmilhttp.send(null): 
9 

} 
而 chkpwd0 函 数 则 弹出 提示 信息 ， 如 果 成 功 ， 则 关闭 当前 页 。chkpwd0 函 数 的 代码 如 下 : 
function chkpwd(form){* 


族 ”获取 名 称 和 密码 。 */ 

var user = document.getElementById(user).value: 
var pwdl = formpwdl.value: 

Var pwd2 = form.pwd2.value; 


上 请。 省 略 部 分 为 表单 验证 */ 
var url = "foundpwd.php?user="+user+"&password="+pwd1: 


xmlhttp.open("GET".url,true): 
xmlhttp.onreadystatechange = function(){ 
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这 xmlhttp.readyState 一 4){ 
var msg = xmlhttp.responseText: 
这 msg —'1){ 
alert( 密 码 修 改 成 功 ， 请 重新 登录 '): 


window.close(): 


} 
; 
xmilhttp.send(null): 
} 
3. 创建 数据 处 理 文件 
foundpwd.php 文件 的 功能 是 根据 用 户 输入 信息 来 检测 数据 表 中 的 数据 ， 并 根据 不 同 的 输入 项 返回 
不 同 的 结果 ， 代 码 如 下 。 


<?php 
include_once ‘conn/conn.php': // 载 入 数据 库 连 接 文件 
$name= $_GET['user']: // 获 取 表单 值 


$answer=$_GET['answer]: 
$password = $_GET[password']: 
Sreback = '0': 
必 ”如 果 变 量 Sanswer 和 Spassword 为 空 ， 说 明 用 户 只 输入 了 会 员 名 称 。 */ 
这 empty($answer) && empty($password)){ 
上 # ”生成 查询 语句 */ 
$namesql = "select * 位 om tb_user Where name = ".$name."": 
族 ”获取 查询 结果 */ 
Snamerst = $conn->execute($namesq]): 
让 ”如 果 查 询 记录 为 1， 说 明 输入 正确 六 
这 $namerst->recordCount0 一 1){ 
上 ”获取 密 保 问题 ， 并 赋 给 变量 Sreack */ 
S$question = $namerst->fields['question']: 
Sreback = $question; 


} 
族 ”如 果 变 量 Sanswer 不 为 空 ， 说 明 用 户 输入 了 密 保 答案 多 
jelse if(!empty(Sanswer)){ 
睛 ”根据 密 保 答案 和 会 员 名 称 ， 生 成 查询 语句 */ 
$answersql = "select * 位 om tb_user Where name = ".$name."" and answer ="".$answer."™"; 
证 ”返回 查询 结果 ， 并 判断 是 否 有 返回 记录 ， 如 果 有 ， 说 明 输入 正确 。 */ 
Sanswerrst = $conn->execute($answersql); 
if($answerrst->recordCount( — 1){ 
Sreback = "1'; 


} 
上 ”如 果 变 量 Spassword 不 为 空 ， 说 明 用 户 输入 了 新 密码 */ 
j}else 这 !empty($password)){ 

入。 根据 用 户 名 称 和 新 密码 更 新 记录 。 */ 

$sql = "select * from tb_user where name =".$name.™™; 

Sarr = aray0: 

Srst = $conn->execute($sqD: 

这 $rst->RecordCount0 — 1){ 
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$arr[password] = md5($password); 
SupdateSQL = $conn->GetUpdateSQL(Srst, $arr,true): 


Sconn->execute($updateSQL); 
Sreback = "1'; 
} 
9 
族 ”输出 返回 值 。*/ 
echo Sreback:; 
?> 
4. 加 载 模板 页 


因为 所 有 登录 模块 的 模板 都 是 不 需要 、 或 者 只 需要 传递 一 两 个 变量 ， 所 以 PHP 加 载 页 的 内 容 比 较 
简单 。 找 回 密码 页 面 的 PHP 加 载 文 件 是 found.php， 代 码 可 参考 配套 光盘 中 的 内 容 。 


26.10 会员 信息 模块 设计 


铬 am 视频 讲解 ， 光盘 \TMNVideo\26\ 会 员 信息 模块 设计 .exe 

用 户 登 录 后 ， 即 可 看 到 会 员 信息 模块 。 在 会 员 信息 模块 中 ， 可 以 执行 查看 、 修 改 个 人 信息 及 密码 ， 
查看 购物 车 和 安全 退出 等 操作 。 本 节 只 对 会 员 信息 模块 中 的 “会 员 中 心 ” 和 “安全 退出 ” 超 链接 进行 
讲解 ， 关 于 “查看 购物 车 ” 超 链接 将 在 商品 模块 中 进行 介绍 。 


26.10.1 会 员 中 心 


单 击 “ 会 员 中心 ” 超 链接 , 会 回 传 给 当前 页 一 个 page 值 , 当前 页 根据 这 个 page 值 来 载 入 member.php 
文件 。member.php 页 面 的 运行 结果 如 图 26.21 所 示 。 


会 员 编号 ， 14 
会 员 名 秘 : tn 

可 保 问题 : nidepergyou 
容 保 答案 3939 
注册 时 间 。 2008-04-23 
清 几 总额: 666634 


图 26.21 “会 员 中 心 ”页 面 的 运行 结果 
1. 创建 PHP 页面 
与 登录 模块 设计 不 同 ， 本 节 首 先 来 创建 PHP 页 面 ， 因 为 该 模块 中 的 模板 需要 使 用 数据 库 中 的 数据 
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及 一 些 动态 信息 ， 这 些 都 需要 在 PHP 页 中 先行 获取 及 处 理 ， 然 后 再 传 给 模板 页 。“ 会 员 中 心 ” 页 面 的 
代码 如 下 。 


<2?php 
session start(); /开启 Session 支持 
include_ once 'conffig php': // 载 入 Smarty 配置 文件 
include_once ‘conn/conn.php': // 载 入 数据 库 连接 文件 


刻 ”查找 用 户 资料 */ 
$sql = 'select * from tb_user where id =".$ SESSIONT'id]: 
S$rst = $conn->execute($sq]); 


Sarr = $rst->GetArray(): // 将 结果 集 输 出 为 数组 
if($_GET['action'] == 'modify’){ // 如 果 动 作为 修改 密码 
S$smarty->display(modifypwd.tpl)): // 则 载 入 修改 密码 模板 页 
}else{ // 否 则 载 入 查看 信息 页 
Ssmarty->assign('arr’, Sarr[0]): /传递 数组 
S$smarty->display('membershow.tpl"):; // 显 示 模 板 
} 
?> 
2. 创建 模板 页 


该 模块 包括 查看 信息 模板 及 修改 密码 模板 。 首 先 介绍 查看 信息 模板 ， 代 码 如 下 : 


<!-- 显示 超 链 接 --> 
<p>{$smarty.session.member}<a href = ' ?page=hyzx ' > 查看 信息 </a><a href = ' ?page = hyzx&action=modify' 
id="mem"> 修 改 密码 </a></p> 


<table> 
<form id = a name = "member " method = " post " action = ”modify info_chk.php " onsubmit = " returm 
mem( member ) 


<!- 显 守 当前 会 员 信息 ， 此 处 为 不 可 更 改 信息 --> 
<tr><td colspan="2"> {$arrname} 信 息 〈 不 可 更 改 信息 ) </td></t> 
<!-- “因为 格式 相同 ， 所 以 只 显示 一 条 ， 其 他 省 略 一 > 
全 员 编 号 : </td><td >&nbsp: {Sarr.id}</td></tr> 


a (可 更 改 信息 ) </td></u> 
<!-- 可 以 修改 的 信息 ， 放 到 表单 元 素 中 -> 
<tr><td> 真 实 姓名 :</td> 
<td><input id="realname" name="realname" type="text" value=" {$arr.realname}" /></td></tr> 
<!-- 省 略 了 部 分 代码 eg a 
<tr><td> 
<input name="enter" type="submit" id="enter" value=" 修 改 " /> 
<input name="reset" type="reset" id="reset" value=" 重 置 " /> 
</td></tr> 
</form> 
</table> 


修改 密码 模板 比 信息 模板 要 简单 一 些 ， 因 为 不 需要 额外 的 传 值 。 模 板 代码 如 下 : 
<!--。 载 入 脚本 文件 -> 
<script language="javascript" src="js/member.js"></script> 
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<p>{$smarty.session.member}<a hre 人 ="?page=hyzx 人 > 查看 信息 </a><a hre 全 '?page=hyzx&action=modify' > 修改 密码 
</a></p> 
<table> 
<!-- ”修改 密码 表单 -~ 
<form id = ”member " name = " member " method = " post " action = " modify pwd chk.php " onsubmit = " return 
pwd(member) "> 
<t><td > 修改 密码 </td></t> 
<tr><td > 原 密码 : </td><td><input id="old" name="old" type="password" /></td></tr> 
<tr><td> 新 密码 : </td><td><input id="new1" name="newl" type="password" /></td></tr> 
<tr><td> 确 认 密 码 : </td><td><input id="new2" name="new2" type="password" /></td></tr> 
<tr><td><input id="enter" name="enter" type="submit" value=" 修 改 " /></td></tr> 
</form> 
</table> 


3. 创建 脚本 文件 
该 模块 的 脚本 文件 和 用 户 注册 模块 类 似 ， 都 是 对 信息 的 合法 性 进行 验证 ， 如 信息 是 否 为 空 、 是 否 


符合 规范 等 。 这 里 不 给 出 代码 ， 读 者 可 以 参考 26.9.1 节 的 内 容 。 


4. 创建 处 理 页 
当 信 息 验证 通过 后 ， 系 统 将 跳 到 处 理 页 ， 进 行 信息 处 理 。 本 模块 的 处 理 页 分 为 信息 修改 和 密码 修 


改 两 个 页 面 。 首 先 介 绍 信息 修改 页 ， 代 码 如 下 : 


<2php 
session start(); /开启 Session 支持 
include_once 'conn/conn php' // 载 入 数据 库 连 接 文件 
$sql = 'select * from tb_user where id='.$_SESSION['id]:; /根据 ID 生成 SQL 查询 语句 
Srst = $conn->execute($sql): // 执 行 SQL 语句 ， 返 回 查询 结果 集 
$mod = array0: /声明 数组 


族 ”将 修改 信息 添加 到 数组 中 */ 
Smod['realname'] = $_POST['realname’]; 
Smod['card'] =$_POST['card']: 
Smod['tel'] =$_POST['Yel]: 
S$mod[phone] = $_POST['phone']: 
$mod[Email] =$_ POST['email]: 
$mod[QQ]=S$_POST['qq]: 
$mod['code] =$_ POST['code']: 
$mod['address] =$_ POST['address']: 


/本 束 于 束 事 于 素 事 束 李 可 可 站 训 事 于 束 于 下 未 束 本 于 可 可可 字 训 可 字 训 束 训 可 束 可 可 二 训 


SupdateSQL = $conn->GetUpdateSQL($rst. $mod):; // 生 成 更 新 语句 
if($conn->execute($updateSQL)) 

echo "<script>alert( 修 改 成 功 "):location=(index.php"):</script>": /修改 成 功 ， 跳 到 首页 
else 

echo "<script>alert(' 修 改 失败 '):history.go(-1):</script>": // 否 则 返回 上 一 页 


密码 修改 页 的 操作 流程 与 信息 修改 页 类 似 ， 只 是 更 新 的 数组 少 ， 只 有 一 个 字段 。 修 改 密码 页 的 代 


人 码 如 下 : 
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<2php 
session start(); /开启 Session 支持 
include_once 'conn/conn php': // 载 入 数据 库 连接 文件 
S$oldpwd = md5($_POST['old"]): // 为 旧 密 码 进行 MD5 加 密 
上 根据 ID 和 MDs 加 密 后 的 密码 查询 用 户 3 
$sql = 'select * from tb_user where id=".$ SESSION['id'].' and password =\".$oldpwd.\"; 
Srst = $conn->execute($sq]); // 返 回 查询 结果 
Smod = array0: // 创 建 更 新 数组 
$mod['password'] = md5($_POST['new1"]): /为 新 密码 进行 MD5 加 密 
S$updateSQL = $conn->GetUpdateSQL(SrstSmod): // 生 成 更 新 语句 
if($conn->execute($updateSQL)) 
echo "<script>alert( 修 改 成 功 "):location=('index.php");</script>"; // 修 改 成 功 ， 返 回首 页 
else 
echo "<script>alert( 修 改 失 败 "):history.go(-1):</script>"; // 否 则 返回 上 一 页 
?> 


26.10.2 ”安全 退出 


当 用 户 需 要 离开 网 站 时 ， 可 以 单 击 “ 安 全 退出 ” 超 链 接 来 调用 logout0 函 数 ， 当 确认 用 户 退 出 后 ， 
跳 转 到 logout 页 面 ， 销 毁 Session， 并 回 到 首页 。 安 全 退出 所 涉及 的 页 面 及 代码 如 下 : 


function logoutO{ 
这 confirm(" 确 定 要 退出 登录 吗 ? ")){ // 输 出 选择 框 ， 用 户 可 以 单 击 “ 确 认 ” 或 “取消 ”按钮 
window.open(logout.php',parent',",false); /如 果 用 户 确 认 退 出 ， 则 打开 logout.php 页 
jelse 
Teturm false; 
<2php 
session_start(): // 开 启 Session 支持 
Session_destroy(: /销毁 Session 
echo '<script>alert(\ 用 户 已 安全 退出 必 ):location=(Vindex.phpV):</script>': // 回 到 首页 
?> 


26.11 商品 展示 模块 


使 m 视频 讲解 ， 光盘 \TM\Video26\ 商 品 展示 模块 .exe 

本 系统 根据 商品 的 类 别 ， 为 用 户 提供 了 多 种 不 同 的 商品 展示 方式 ， 包 括 推荐 商品 、 最 新 商品 和 热 
门 商品 等 ， 能 够 使 消费 者 有 目的 地 选 购 一 些 商 品 。 商 品 信息 对 商品 的 一 些 属性 进行 了 描述 ， 还 提供 了 
商品 的 实物 图 片 ， 为 用 户 提供 信息 ， 让 用 户 对 商品 有 更 多 的 了 解 。 商 品 展示 模块 对 电子 商务 平台 来 说 
尤为 重要 。 本 系统 中 商品 展示 模块 的 运行 结果 如 图 26.22 所 示 。 

因为 推荐 商品 、 最 新 商品 和 热门 商品 的 实现 方法 和 过 程 基本 相同 ， 所 以 本 节 只 讲解 推荐 商品 模块 ， 
其 他 的 程序 可 参见 本 书 配 套 光盘 。 
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各 到 相机 
388 5 仙 场 价 ，333 再 场 价 ，1339 
会员 价 ，349.2 元 会 员 从 ;1599.2 元 会 员 价 :349,2 会 员 价 ， 1639.2 


自作 芋 数码 相机 
而 场 价 ，388 元 市 场 ff，1838 元 


图 26.22 商品 展示 模块 页 面 
26.11.1 创建 PHP 页 


既然 是 商品 展示 模块 ， 首 先 就 是 要 取得 商品 记录 。 在 数据 库 设计 一 节 中 已 经 介绍 ， 商 品 字段 isnom 
表示 商品 是 否 被 推荐 ， 如 果 该 字段 为 1， 即 为 推荐 ， 否 则 为 不 推荐 。 所 以 在 PHP 页 面 中 ， 首 先 要 获取 
数据 表 中 isnom 字段 属性 为 1 的 记录 ， 因 为 受 页 面 限制 ， 所 以 只 返回 4 条 记录 。 首 页 中 的 推荐 商品 页 
面 的 代码 如 下 : 


<?php 
include_once ‘conn/conn.php'; // 载 入 数据 库 连 接 文 件 
include_once 'config.php'; // 载 入 模板 配置 文件 


让 ”根据 isnom 字段 ， 生 成 SQL 语 句 */ 


$sql = "select id,name,pics.m price.v_price from tb_commo where isnom = 1": 


Snum = 4: /设置 提取 记录 条 数 

Srst = $conn->SelectLimit($sql, $num): // 使 用 SelectLimit 方法 获取 记录 集 
S$nomarr = $rst->GetArray(): // 将 记录 集 保存 为 数组 
$smarty->assign(nomarr.Snomarr): /将 数组 传递 到 模板 页 
S$smarty->display(Cnominate tpl): // 显 示 模板 


26.11.2 ”创建 模板 页 


记录 集 数组 被 传递 到 模板 页 后 ,模板 页 使 用 foreach 标签 输出 商品 信息 ， 并 添加 相应 的 操作 按钮 和 
超 链接 。 模 板 页 中 一 共有 显示 更 多 商品 、 查 看 商品 和 放 入 购物 车 3 个 事件 。 
回 ” 当 单 击 “ 更 多 商品 ” 超 链 接 时 ， 将 重新 加 载 本 页 面 ， 并 传递 一 个 page 变量 。switch 语句 会 根 
据 page 值 来 显示 。 
回 ” 单 击 “ 查 看 商品 ”按钮 时 ， 将 触发 onclick 事件 ， 并 调用 openshowcommo0 函 数 ， 同 时 ， 商 品 
ID 会 作为 函数 的 唯一 参数 被 传递 。 
回 ” 当 单 击 “ 放 入 购物 车 ”按钮 时 ， 同 样 会 触发 onclick 事件 ， 并 调用 buycommo0 函 数 ， 唯 一 的 
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参数 也 是 商品 的 人 D。 
商品 模板 页 面 的 代码 如 下 : 


<!-- 载 入 js 脚本 文件 -> 
<script language="javascript" src="js/createxmlhttp.js"></script> 
<script language="javascript" src="js/showcommo.js"></script> 
<table border="0" cellpadding="0" cellspacine="0"> 
<!-- “更 多 商品 ” 超 链 接 -> 
<tr><td><a href="?page=new">&gt:&gt:more&lt.&lt.</a></td><td rowspan="3">&nbsp;</td></tr> 
<tr><td >&nbsp:</td> 
<!-- 使 用 Smarty 的 foreach 标签 ， 循 环 输出 数组 ”--> 
{foreach key=key item=item from=$nomarr} 
<td> 
<table border="0" cellpadding="0" cellspacing="0" > 
<t><td> 
<!-- 商品 图 片 显示 。--> 
<img src=" {$item.pics}" width="100" height="80" alt=" {$item.name}"></td></tr> 
<tr><td>&nbsp; {$item.name}</td></tr> 
<tr><td> 市 场 价 ， {$item.m _price}&nbsp: 元 </td></t> 
<tr><td> 会 员 价 {$item.v_price}&nbsp; 元 </td></tr> 
<tr><td> 
<!-- “查看 商品 ”按钮 -> 
<input id = " showinfo " name = " showinfo " type = " button " Value = "" onclick = " openshowcommo 
({Sitem.id})"/> 
<!-- “ 放 入 购物 车 ”按钮 --> 
<input id = " buy " name = " buy " type = " button " value = "" onclick = "retum buycommo 
( {Sitem.id} ) " </td></u></table></td> 
<!-- 循环 结束 -> 
{/foreach} 
<td>&nbsp;</td></tr> 
<tr><td colspan="6">&nbsp:;</td></tr> 
</table> 


26.11.3 js 脚本 页 面 


在 模板 页 中 的 3 个 链接 ， 其 中 两 个 都 用 到 了 js 函数 。 通 过 js 函数 ， 当 单 击 “ 查 看 商品 ”按钮 时 ， 
系统 会 弹出 一 个 新 的 页 面 ， 并 显示 商品 的 详细 信息 ; 当 单 击 “ 购 买 ”按钮 时 ， 该 商品 将 会 被 放 到 当前 
用 户 的 购物 车 中 ， 如 果 没 有 登录 用 户 或 商品 已 添加 ， 则 弹出 提示 信息 。js 脚本 文件 的 代码 如 下 : 

心 ”查看 商品 信息 函数 ， 将 打开 一 个 新 页 面 六 


function openshowcommo(key){ 
open('showcommo.php?id="+key,"_blank',"width=560 height=300'.false): 


} 
片 “将 购买 商品 添加 到 购物 车 中 ， 将 在 26.12 节 中 进行 讲解 。*/ 
function buycommo(key){ 


由 
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显示 更 多 商品 列表 和 商品 详细 信息 页 的 实现 过 程 和 26.11.1 节 、26.11.2 节 所 述 类 似 , 只 是 显示 更 多 
字段 信息 而 已 ， 这 里 不 再 资 述 。26.12 节 将 重点 讲解 购物 车 的 实现 。 


26.12 ”购物 车 模块 设计 


| 视频 讲解 : 光盘 \TMVVideo\26\ 购 物 车 模块 设计 .exe 

购物 车 在 电子 商务 平台 中 是 非常 关键 的 一 个 功能 模块 。 购 物 车 保留 用 户 选择 的 商品 信息 ， 用 户 可 
以 在 购物 车 内 设置 选 购 商品 的 数量 ， 显 示 选 购 商品 的 总 金额 ， 清 除 选 择 的 全 部 商品 ， 以 及 重新 选择 商 
品 。 购 物 车 页 面 运行 结果 如 图 26.23 所 示 。 


商品 名 黎 购买 娄 重 折扣 率 合计 
[a 自行 车 9 9 1047.6 
厂 数码 相机 5 日 496 
口 洗衣 机 I 2399.4 
[a i 日 4395. 


全 选 区 过 。 出 除 选择 
图 26.23 购物 车 页 面 运行 结果 
购物 车 模块 主要 实现 以 下 功能 :添加 商品 、 删 除 商品 、 更 改 商品 数量 。 


26.12.1 添加 商品 


在 商品 展示 模块 中 ， 单 击 指定 商品 中 的 “购买 ”按钮 ， 即 可 将 物品 放 到 购物 车 中 ， 并 进入 到 “ 购 
物 车 ”页 面 。 从 26.11 节 中 已 经 了 解 到 “购买 ”动作 调用 的 是 buycommo0) 函 数 ， 购 买 商品 的 ID 是 该 函 
数 的 唯一 参数 。 下 面 就 来 看 buycommo0 函 数 的 功能 结构 。 此 函数 代码 如 下 : 


/添加 商品 ， 同 时 检查 用 户 是 否 登录 、 商 品 是 否 重 复 等 */ 
function buycommo(key){ 
上 # ”根据 商品 ID， 生 成 rl */ 
var url = "chklogin.php?key="+key: 
上 # “使 用 xmlhttp 对 象 调用 chklogin.php 页 */ 
xmlhttp.open("GET",url,true); 
xmlhttp.onreadystatechange = function(O){ 
这 xmlhttp readyState 一 4){ 
var msg = xmlhttp.responseText: 
入 “用户 没有 登录 */ 
iftmsg —'2){ 
alert( 请 您 先 登录 '): 
Tetum false; 
Jelse iftmsg — 3){ 
上 请。 商品 已 添加 */ 
alert( 该 商品 已 添加 7: 
Tetum false: 
jelsef 
让 ”显示 购物 车 */ 
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location="index.php?page=shopcar'; 
} 


xmlhttp.send(nulD): 


可 以 看 到 , buycommo0 函 数 通过 xmlhttp 对 象 调用 chklogin.php 页 , 并 根据 回 传 值 作出 相应 的 处 理 ， 
chklogin.php 页 才 是 将 商品 添加 到 购物 车 中 的 操作 页 。chkloginphp 页 的 代码 如 下 : 


<2php 
Session_Start(: 
fe 
* 工 表示 添加 成 功 
2 表示 用 户 没 有 登录 
3 表示 商品 已 添加 过 
4 表示 添加 时 出 现 错误 
5 表示 没有 商品 添加 


二 


include_once 'conn/conn.php': 
Sreback = '0': 
这 empty($_SESSION[member])){ 
Sreback = "2'; 
}else{ 
Skey =$_GET['key']: 
这 $key =—"){ 
Sreback = "5'; 
}else{ 
$id = (inb$_ SESSION['id]: 
$boo = false; 
$addshop = array0: 


$sql = "select id,shopping from tb_user where id = ".$id; 


S$rst = $conn->execute($sq]); 
$shopcont = Srst->fields['shopping’]: 
这 !empty($shopcontb){ 
Sarr = explode('(@'.$shopcont): 
foreach($arr as $value){ 
if($key 一 $value[0]){ 
Sreback = "3'; 
S$boo = true; 
break: 
} 


上 
这 !Sboo){ 


/开启 Session 支持 


// 载 入 数据 库 连接 文件 

/声明 返回 值 

/如 果 Session 值 为 空 ， 说 明 没有 登录 
/参见 头 注释 


/获取 商品 也 


// 获 取 登 录 会 员 ID 号 
/设置 一 个 布尔 变量 ， 初 始 为 false 
// 数 据 库 更 新 数组 

// 生 成 当前 用 户 的 查询 语句 

/返回 当前 用 户 记录 集 

// 找 到 shopping 字段 

/如 果 字 段 不 为 空 ， 说 明 已 有 商品 
/将 字段 用 “@” 拆 分 并 另存 数组 
/循环 输出 数组 内 容 

// 判 断 需 要 添加 的 商品 是 否 存在 
// 参 见 头 注释 

/同时 布尔 变量 变 为 tue 

/停止 循环 


/如 果 布尔 值 没有 改变 ， 再 添加 商品 


请 “将 商品 数量 默认 设 为 1， 连同 商 品 IDD 保存 到 字 串 中 */ 


S$shopcont ='@'.Skey.…1 

请 “将 商品 字 串 保存 到 更 新 数组 中 */ 
$addshop['shopping ] = $shopcont: 

证 ”生成 更 新 语句 */ 


SupdateSQL = $conn->GetUpdateSQL(S$rst.$addshop): 


广 ” 更 新 数据 表 */ 
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请 ”如果 有 结果 集 ， 则 将 结果 集 另 存 为 数组 */ 
Stmparr = Srst- Re 
$commarr = array| 
上 请。 输出 和 字段 值 地 
foreach($tmparras Svalue){ 
让 ”使 用 “@” 过 和 分 了 得 到 数组 */ 
Stmpnum = explode('(@',$value):; 
睛 ”得 到 购买 商品 种 类 */ 
$shopnum = count($tmpnum); 
启 ”商品 总 价值 */ 
S$sum = 0; 
局 ”数组 循环 */ 
foreach($tmpnum as $key => $vD{ 
上 ”使 用 逗号 “,” 拆 分 单一 的 商品 信息 3 
$s_commo = pl ,3SvD: 
局 ”根据 保存 的 商品 信息 查找 商品 */ 
$sql2 = "select id,name,m price,fold,v_price from tb_commo"; 
$commsql = $sql2." where id = ".$s_commo[0]: 
请 “返回 结果 集 */ 
$commrst = $conn->execute($commsq]):; 
上 请 ”将 结果 集 另存 数 组 。*/ 
$arr = $commrst->GetArray(): 
辣 将 壳 要 显示 的 信息 外 理 后 保存 到 数组 中 a 
$ar[0][mnum'] = $s_commo[1]: 
S$ar[0]['otal] = $Ss_commo[1]*$arr[0][v_price]: 
$sum += $arr[O]['total’]; 
$commar[Skey] = $arr[0]; 
} 


} 
上 # “将 得 到 的 两 个 数组 和 总 消费 金额 传递 给 模板 */ 
$smarty->assign(shoparr.Sshopnumy): 
$smarty->assign(commarr.$Scommarr): 
S$smarty->assign('sum'.$sum): 
Ssmarty->assign('title',' 我 的 购物 车 "): 
族 ”显示 购物 车 模板 。 */ 
$smarty->display(myshopcar.tpl): 

?> 


商品 的 模板 页 不 仅 要 负责 将 传 入 的 商品 信息 数组 显示 出 来 ， 而 且 还 要 提供 可 以 对 商品 进行 修改 、 
删除 等 操作 的 接口 。 模 板 页 的 代码 如 下 : 


<!--” 载 入 使 用 到 的 js 脚本 文件 -> 

<script language="javascript" src="js/createxmlhttp.js"></script> 

<script language="javascript" src="js/shopcar.js"></script> 

<table> 

<!-- ”购物 车 表单 -> 

<form id="myshopcar" name="myshopcar" method="post" action="#"> 
<tr><td> 我 的 购物 车 </td></tr> 
<tr><td >&nbsp:</td><td> 商 品名 称 </td><td> 购 买 数量 </td><td> 市 场 价格 </td> 

<td> 会 员 价格 </td><td> 折 扣 率 </td><td> 合 计 </td></t> 


PHP 开发 实战 宝典 
<!-- 使 用 foreach 表单 循环 输出 商品 种 类 -~ 


{foreach key=key item=item from=$commarr} 
<!-- ”删除 复 选 框 ， 名 称 用 数组 表示 ， 每 个 复 选 框 的 值 为 商品 的 ID 号 -> 
<tr><td><input id= "chk" name= "chk[]" type="checkbox" value=" {$item.id}"></td> 
<!-- ”显示 该 商品 的 名 称 -> 
<td><div id= "c_ name{f$key}"> &nbsp:{fSitem name}</div></td> 
<td> 
<!-- 商品 数量 文本 框 每 个 复 选 框 的 名 称 为 “cnum>”+key 值 -> 


<input id = " cnum{S$key} " name = ”cnum{S$Skey} " type = " text " value = " {Sitem.num} " 


cvp( {Skey}, {Sitem.v_price}, {$shoparr})"></td> 
<!-- 商品 的 其 他 信息 -> 
<td><div id="m price{$key}">&nbsp; {$item.m price}</div></td> 
<td><div id="v_price {Skey}">&nbsp; {Sitem.v_price}</div></td> 
id="fold {$key}">&nbsp. {Sitem.fold}</div></td> 
="total {$key}">&nbsp: {$item.total}</div></td> 


{/foreach} 
<tr> 
<td colspan="3"> 
<!-- 全 选 、 反 选 和 删除 操作 ”--> 
<a href="#" onclick="return alldel(myshopcar)"> 全 选 </a> 
<a href="#" onclick="retum overdel(myshopcar);"> 反 选 </a> 
<input type="button" value=" 删 除 选 择 " onClick = 'return del(myshopcar):></td> 
<td> 
<!-- 继续 购物 --> 
<input type="button" value=" 继 续 购 物 " onclick="return conshop(myshopcar)" /></td> 


<td> 
<!-- 将 当前 用 户 名 保存 到 隐藏 域 中 --> 
<input id="uid" name="uid" type="hidden" value=" {$smarty.session.member}" > 
<!-- 结算 ， 去 收银 台 --> 
<input type="button" class="btn" value=" 去 收银 台 " onclick="return formset(form)" /></td> 
<td colspan="2"><div id='sum> 共 计 : {$sum}&nbsp; 元 </div></td> 
</t> 
</form> 
</table> 


26.12.3 ”更 改 商 品 数量 


发 


onkeyup 事件 调用 cvp0 函 数 实现 的 。 


对 于 新 添加 的 商品 , 默认 的 购买 数量 为 1, 在 购物 车 页 面 可 以 对 商品 的 数量 进行 修改 。 


onkeyup = 


当 商 品 数量 
生变 化 时 ， 商 品 的 “合计 ”金额 和 商品 总 金额 会 自动 发 生 改变 。 该 功能 是 通过 触发 text 文本 域 的 
cvp0 函 数 有 3 个 参数 : 商品 ID、 商 品 单价 和 商品 类 别 。 


首先 通过 商品 ID 得 到 要 修改 商品 的 相关 表单 和 标签 属性 , 然后 通过 商品 单价 和 输入 的 商品 数量 计 
算 该 商品 的 合计 金额 ， 接 着 使 用 for 循环 得 到 其 他 商品 的 合计 金额 ,最 后 将 所 有 的 合计 金额 累加 ， 并 输 
出 到 购物 车 页 面 。cvp0 函 数 的 代码 如 下 : 


必 自动 刷新 总 金额 
*key: 商品 ID 
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* vpr: 商品 单价 
* shoparr: 商品 种 类 数 
je 
function cvp(key.vpr.shoparn) { 
var n_pre = "total': 
var num = 'cnum'+key .toString(): 
var total = n_pretkey.toString(): 
vart number = document.getElementById(num).value; 
var tt] = t_number * vpr; 
document.getElementById(total).innerHTML = ttl: 
Var sm = 0; 


for(var i= 0; i < shoparr; i+H+){ 


/div 标签 的 ID 前 缀 

/根据 key 值 生 成 文本 域 的 ID 值 

/根据 key 值 生成 div 标签 的 ID 值 
/获取 输入 的 商品 数量 
/根据 商 品 数量 和 单价 ， 计 算 商 品 金额 
/更 新 商品 总 金额 

/所 有 商品 的 总 金额 ， 初 始 为 0 

/根据 商品 种 类 数 ， 循 环 得 到 其 他 商品 金额 


Var aaa = document.getElementById(n preti.toString()).innerText: 


sm += parseInt(aaa): 


// 将 所 有 商品 金额 累加 


} 
document.getElementById('sum').innerHTML = ' 共 计 : +sm+" 元: 
} 
这 里 所 更 改 的 商品 数量 并 没有 被 保存 到 数据 库 中 ， 如 果 希 望 保存 ， 则 单 击 “ 继 续 购 物 ” 按 钮 ， 即 
可 将 商品 数量 更 新 到 数据 库 中 。 该 功能 将 在 26.12.5 节 中 实现 。 


26.12.4 ”删除 商品 
当 对 添加 的 商品 不 满意 时 ， 可 以 对 商品 进行 删除 操作 。 操 作 流程 为 : 首先 选中 要 删除 的 商品 前 面 


的 复 选 框 ， 如 果 全 部 删除 ， 则 可 以 单 击 “ 全 选 ”按钮 ， 或 “反选 ”按钮 ;然后 单 击 “ 删 除 选择 ”按钮 ; 
在 弹出 的 警告 框 中 单 击 “ 确 定 ” 按 钮 ， 商 品 将 被 全 部 删除 。 删 除 商品 的 操作 流程 如 图 26.24 所 示 。 
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26.24 ”删除 商品 流程 
所 有 的 删除 操作 都 是 通过 js 脚本 文件 shopcarjs 来 实现 的 ， 相 关 的 函数 包括 alldel0 函 数 、overdel0 
函数 和 del0 函 数 。 下 面 分 别 介绍 这 3 个 函数 的 实现 过 程 。 
alldel0 函 数 和 overdel0 函 数 实现 的 原理 比较 简单 ,通过 触发 onclick 事件 来 改变 复 选 框 的 选中 状态 。 
实例 代码 如 下 : 


让 ”全 部 选择 */ 
function alldel(form){ 
Var leng = form.chk.length: // 获 取 复 选 框 数量 
ifl(leng==undefined){ // 如 果 等 于 undefined， 说 明 只 有 一 个 复 选 框 
if(!form.chk.checked) 
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form.chk.checked=tme: 
}else{ 
for( vari= 0;i<leng; iH){ 
这 !form.chk[i].checked) 
form.chk[il].checked = true; 
} 
} 


Tetum false; 


// 将 复 选 框 置 于 选中 状态 
Jundefined， 说 明 有 多 个 复 选 框 
/使 用 for 循环 ， 将 所 有 复 选 框 选 中 


} 
族 ”反选 ， 就 是 将 选中 的 复 选 框 取消 选中 ， 而 未 被 选中 的 复 选 框 则 被 选中 */ 


function overdel(form){ 
Var leng = form.chk.length: 
if(leng—=undefined){ 
if(!form.chk.checked) 
form.chk.checked=true: 
else 
form.chk.checked=false; 
}else{ 
for( vari= 0; i< leng; iH){ 
if(!form.chk[il].checked) 
form.chk[i].checked = true; 
else 
form.chk[i].checked = false: 
外 
retum false; 


} 


使 用 alldel 或 overdel 选中 复 选 框 后 ， 即 可 调用 alldel0 函 数 来 实现 删除 功能 。 


// 获 取 复 选 框 个 数 
// 如 果 leng 为 undefined， 说 明 只 有 一 个 复 选 框 


// 否 则 ， 说 明 有 多 个 复 选 框 
// 使 用 for 循环 ， 对 所 有 复 选 框 进行 操作 
/根据 复 选 框 checked 属性 的 情况 ， 进 行 反 向 选择 


alldel0 函 数 首先 使 用 


for 循环 ， 将 被 选中 的 复 选 框 的 value 值 取出 并 存 成 数组 ， 然 后 根据 数组 生成 ul， 并 使 用 xmlhttp 对 象 
调用 这 个 url， 当 处 理 完毕 后 ， 根 据 返回 值 ， 或 弹出 提示 ， 或 刷新 本 页 。 该 函数 代码 如 下 : 


让 ”删除 记录 */ 
function del(form){ 
if(!window.confirm(' 是 否 要 删除 数据 ??)){ 
}else{ 
Var leng = form.chk.length:; 
if(leng—undefined){ 
if(!form.chk.checked){ 


alert(' 请 选取 要 删除 数据 !"): 


jelse{ 
rd = form.chk.value: 


var url = "delshop.php?rd="+rd: 


xmlhttp.open("GET".url.true): 


Xmlhttp.onreadystatechange = delnow: 


xmlhttp.send(nulD): 
} 
}else{ 
var rd=new Array(): 


$88 


// 返 回复 选 框 的 长 度 


// 如 果 只 有 一 个 复 选 框 ， 且 处 于 选中 状态 
// 将 复 选 框 的 value 值 直 接 赋 给 变量 rd 

// 根 据 rd 生成 url 

// 调 用 xmlhttp 对 象 

// 调 用 delnow 函数 


// 如 果 复 选 框 为 多 个 
/声明 数组 
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Varj=0: 
for(vari=0:i<leng: it+){ /循环 检查 复 选 框 状态 
这 form.chk[i].checked){ 
rd[j++] = form.chk[].value: // 将 被 选中 的 复 选 框 的 value 值 存 到 rd 内 
} 
} 
ifrd—"){ 
alert( 请 选取 要 删除 数据 !"): 
jelse{ 
var url = "delshop.php?rd="+rd: // 解 释 同 上 


xmlhttp.open("GET",url,true): 
xmlhttp.onreadystatechange = delnow: 
Xmlhttp.sendCnulD): 


} 
} 
Teturn false; 
; * ”显示 状态 */ 
function delnowO{ 
if(xmlhttp.readyState 一 4){ 
这 xmlhttp.status 一 200){ 
var msg = xmlhttp .responseText: // 获 取 xmlhttp 对 象 返 回 的 文本 值 
这 msg !="1){ 
alert( 删 除 失败 7: // 如 果 为 1， 说 明 删 除 失败 
jelse{ 
alert(' 删 除 成 功 "): 
location=(?page=shopcar):; /否则 ， 说 明 删除 成 功 ， 刷 新 购物 车 


26.12.5 ”保存 购物 车 


当 用 户 希 望 保存 商品 数量 时 ， 可 以 单 击 “ 继 续 购物 ”按钮 。 这 时 ， 系 统 将 触发 onclick 事件 调用 
conshop0 函 数 来 保存 数据 。 该 函数 有 一 个 参数 ， 就 是 当前 表单 的 名 称 。 在 conshop0 函 数 内 ， 根 据 复 选 
框 和 商品 数量 文本 域 ， 生 成 两 个 数组 fst 和 snd， 分别 保 存 商 品 ID 和 商品 数量 。 这 里 要 注意 : 两 个 数组 
的 值 是 要 相互 对 应 的 ， 如 商品 1 的 ID 保存 到 fst[1] 中 ， 那 么 商品 1 的 数量 就 要 保存 到 snd[1] 中 。 然 后 
根据 这 两 个 数组 生成 一 个 url, 使 用 XMLHttpRequest 对 象 调用 url, 最 后 根据 回 传 信息 作出 相应 的 判断 。 
conshop0 函 数 的 代码 如 下 : 


族 ”更 改 商 品 数量 */ 


function conshop(form){ 
var n pre = 'cnum'; // 商 品 数量 文本 域 前 缀 
var lang = form.chk.length: // 获 取 复 选 框 的 数量 


睛 ”如 果 只 有 一 个 复 选 框 ， 那 么 将 商品 ID 和 商品 数量 直接 保存 到 变量 中 */ 
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这 lang 一 undefined){ 
Var fst = form.chk .value: 
var snd = form.cnum0.value: 


刻 ”否则 ， 将 商品 ID 和 对 应 的 商品 数量 保存 到 两 个 相应 的 数组 中 。*/ 


}else{ 
var fst= new Array(): /商品 攻 数 组 
var snd = new Array(): // 商 品 数量 数组 


店 ”循环 获取 复 选 框 的 value 值 和 商品 数量 文本 框 的 value 值 */ 
for(var i= 0; i< lang; 计 +){ 
var nm =n preti.toString(O); 
= document.getElementById(nm).value; 
让 对 商品 数量 文本 杠 进 行 判 电 不 允许 为 空 ， 而 且 不 允许 为 非 数字 输入 */ 
这 stmp 一 "isNaNGtmp)){ 
alert(' 不 允许 为 空 、 必 须 为 数字 '); 
document.getElementById(nm).selectO:; 
Teturmn false; 
1 
snd[i] = stmp: 
Var fmp = form.chk[i].value; 
fst[i] = fump: 
} 
} 
Var url = 'changecar.php?fst="+fst+'&snd="+snd; /生成 url 
xmlhttp.open("GET".urLtrue): // 调 用 xmlhttp 对 象 
Xmlhttp.onreadystatechange = updatecar: // 调 用 updatecar 函数 
xmlhttp.send(nul): 


} 
请 “对 xmlhttp 对 象 的 返回 值 进行 处 理 。*/ 
function updatecarO{ 
这 xmlhttp.readyState — 4){ 
var msg = xmlhttp.responseText: 


这 msg —'1){ 

location='index.php': // 如 果 操 作成 功 ， 返 回首 页 
}else{ 

alert(' 操 作 失 败 '): // 否 则 提示 错误 


} 


} 


函数 中 调用 的 changecarphp 页 为 数据 处 理 页 ， 该 页 将 商品 ID 和 商品 数量 进行 重新 排列 ， 并 保存 
到 shopping 字段 内 。 该 页 面 代码 如 下 : 


<?php 
session start(): /开启 Session 支持 
include once 'conn/conn .php': // 载 入 数据 库 连接 文件 
$sql = 'select id.shopping from tb_user': // 生 成 SQL 查询 语句 
$sql =" where id =".(int)$_SESSIONT'id]: 
S$fst = $_GET['fst]: // 获 取 商 品 了 D 
$snd=$ GET['snd]: // 获 取 商 品 数量 
Sreback = '0': /设置 返回 值 ， 默 认为 0 
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26.13.1 显示 订单 


formsetO 函 数 的 作用 是 将 商品 信息 整理 后 ， 通 过 open 方法 打开 settle php 页 来 显示 订单 ， 并 将 整理 
后 的 商品 信息 一 并 传 过 去 。formset0 函 数 的 代码 如 下 : 


function formset(form){ 
var uid = form.uid.value; // 获 取 订 单 提交 人 的 名 称 
varn pre ='cnum'; // 商 品 数量 文本 前 级 

var lang = form.chk .length: // 复 选 框 个 数 


让 ”如 果 复 选 框 只 有 1 个 */ 
if(lang — undefined){ 


Var fst = form.chk.value: /商品 ID 
var snd = form.cnum0.value: /商品 数量 
店 ” 当 有 多 个 复 选 框 时 */ 
}else{ 
Var fst= new Array(): 


var snd = new Array():; 
睛 “使 用 for 循环 ， 获 取 商 品 数量 和 商品 ID 六 
for(vari=0:i<lang: iHH){ 
var nm =n preti.toString(); 
Var stmp = document.getElementById(nm).value: 
这 stmp 一 "||iSNaNGstmp)){ 
alert( 不 允许 为 空 、 必 须 为 数字 7); 
document.getElementById(nm).selectO: 
Tetum false; 
} 
snd[i] = stmp: 
var fnp = form.chk{i].value; 
fst[i] = ftmp:; 


有 
上 请 “使 用 open 方法 ， 打 开 settle php 页 ， 并 将 当前 会 员 名 称 、 商 品 ID 和 商品 数量 的 值 传 过 去 */ 
‘open('settle.php?uid="+uidt+'&fst="+fst+'&snd="+snd,'_blank',"width=420 height=220',false); 


[本 说 明 : 因为 open 方法 使 用 了 _blank 参数 来 打开 一 个 新 的 页 面 ，Session 值 传 不 过 去 。 所 以 这 里 使 用 
隐藏 域 来 传递 会 员 名 称 。 


26.13.2 ”填写 订单 


settle.php 直接 将 接收 的 值 传 给 settle.tpl 模板 ， 并 载 入 settle.tpl 模板 。settle php 页 面 的 代码 如 下 : 


<2?php 
include_ once 'config.php'; // 载 入 Smarty 配置 文件 
S$fst = $_GET['fst]: /获取 get 属性 值 
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settle_ chk.php 页 的 代码 如 下 : 
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<?php 


诬 


认 


获取 表单 值 ， 并 存储 到 添加 数组 中 六 
include_ once 'conn/conn.php': 
$sql = "select * from tb form where id= -1"; 
S$rst = $conn->execute($sq]); 
$addform = array(): 
$addform['vendee]=$_ POST[mid]:; 
$addform['commo id] =$_ POST[t]: 
$addform['commo num']=$ POST['snd]: 
根据 商品 ID 和 商品 数量 ， 获 取 所 需 数 据 */ 
$addform['formid'] =time0 
Stmpid = explode(','.$addform['commo id]): 
$tmpnm = explode(',',$addform['commo_num'"]); 
$number = count($tmpid): 
族 ” 当 购 买 商品 种 类 大 于 1 时 */ 
这 $number >1){ 

Stmpna = array(); 

Stmpvp = arrayO; 

Stmpfd = array(): 

Stmptt = 0: 

店 ”使 用 for 循环 获取 各 种 商品 的 信息 。*/ 

for($i = 0; $i < Snumber: $iH+){ 

让 ”生成 查询 语句 ， 执 行 SQL， 最 后 返回 查询 结果 集 六 


/提交 订 单 用 户 
/购买 商品 了 
/购买 商品 数量 


1/ 订单 号 

/将 商品 ID 存 为 数组 
// 将 商品 数量 存 为 数组 
/获取 商品 数组 长 度 


// 商 品名 称 数 组 
// 商 品 单价 数组 
// 商 品 折扣 数组 
// 商 品 总 额 数 组 


S$tmpsql = "select name,v_price,fold from tb_commo where id = ".$tmpid[$i]; 


S$tmprst = $conn->execute($tmpsq]); 
局 “将 每 种 商品 的 信息 ， 放 到 对 应 的 数组 中 。*/ 
Stmpna[$i] = $tmprst->fields[mame']: 
S$tmpvp[$i] = $tmprst->fields['v_price']: 
Stmpfd[$i] = $tmprst->fields['fold']: 
S$tmptt += $tmprst->fields['v_price’] * $tmpnm[$i]: 
} 


必 ”将 获取 的 信息 数组 分 别 生成 长 字符 串 ， 数 组 值 之 间 使 用 逗号 “,” 分 隔 。 */ 


$addform['commo_name'] = implode(. .Stmpna): 
$addform['agoprice'] = implode(',',$tmpvp): 
S$addform['fold] = implode(',',.$tmpfd); 
$addform['total] = $tmptt: 

上 请。 当 购 买 一 种 商品 时 */ 

}else 这 S$number 一 1){ 


/商品 名 称 
/商品 价格 
/商品 折扣 
/商品 总 额 


$tmpsql = "select name,v_price.fold from tb_commo where id = ".Stmpid[0]: 


Stmprst = $conn->execute($tmpsq]); 
$addform['commo_name'] = $tmprst->fields[mame']: 
$addform['agoprice'] = $tmprst->fields['v_price']: 
$addform['fold] = Stmprst->fields['fold]: 
$addform['total] = $tmprst->fields['v_price’] * Stmpnm[0]: 
谨 ”没有 商品 时  */ 
}else{ 
echo 'emror : 
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exit(); 


» 
上 请。 将 表单 的 其 他 信息 存 入 添加 数组 */ 


S$addform['taker] = $_ POST['aker]: // 收 货 人 
$addform['code] =$_POST['code']: // 邮 编 

$addform['tel] =$_ POST['el]: /联系 电话 
$addform['address'] = S$_POST['address']: /地 址 

$addform['del method] = $_POST['del]: // 送 货 方式 
$addfomm[pay_method] =$_POST['pay’]: /付款 方式 
$addform['state] ='0: // 订 单 状态 ，0 为 未 处 理 
SInsertSQL = $conn->GetInsertSQL(S$rst,$addform); // 生 成 SQL 添加 语句 


这 false 一 $conn->execute($InsertSQL)){ 
局 如果 购买 失败 ， 返 回 上 层 */ 
echo "<script>alert(' 购 买 失败 '):history.back:</script>"; 

}else{ 
局 ”如 果 成 功 ， 删 除 购物 车 信息 ， 并 显示 订单 信息 */ 
$updsql = "select * 位 om tb_user where name =".$ POST[uid]."": 
Supdrst = $conn->execute($updsq]); 
Sarr = array(): 
Sarrf'consume'] = $addform['total’]: 
Sarr['shopping’] = "; 
$UpdateSQL = $conn->GetUpdateSQL($updrst, $arr); 
S$conn->execute($UpdateSQL): 
echo "<script>top.opener.location.reloadO;</script>"; 
echo "<script>open('forminfo.php?fid=$fid',' blank','width=600 height=450',false);</script>™; 
echo “<script>window..close(); </script>"; 


26.13.4 反馈 订单 


订单 提交 成 功 后 ，forminfo.php 页 会 将 新 添加 的 订单 反馈 给 用 户 ， 并 提醒 用 户 保存 订单 号 ， 以 便 根 
据 订 单 号 来 付款 、 查 询 及 处 理 问 题 。 反 馈 订 单 页 面 的 运行 结果 如 图 26.26 所 示 。 


CE lc 


EE Os 


图 26.26 反馈 订单 页 面 的 运行 结果 
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forminfo.php 页 的 代码 如 下 : 

<?php 
include_once 'conn/conn .php': // 载 入 数据 库 连接 文件 
include_once 'config php': // 载 入 Smarty 模板 文件 
$id=$_ GET[fid]: /获取 订单 ID 
$sql = "select * from tb_form where id = ".$id: /根据 ID 生成 查询 语句 
Srst = $conn->execute($sq]): // 执 行 SQL 语句 ， 返 回 结果 集 
S$formarr=$rst->GetArray0): /将 结果 集 存储 为 数组 
Scommname = explode(,Sformar[0]['commo_name]): // 将 商品 名 称 存储 为 数组 
Scommnumber = explode(',", $formarr[0]['commo_num’]):; // 将 商品 数量 存储 为 数组 
S$commagoprice = explode(',", $formarr[0]['agoprice']): // 将 商品 单价 存储 为 数组 
S$commfold = explode(','. $formarr[O]['fold"]): // 将 商品 折扣 率 存储 为 数组 


?> 


上 “将 各 个 数组 传 给 模板 ， 最 后 显示 模板 所 
S$smarty->assign('formarr', $formarr[0]); 
$smarty->assign('commname', $commname); 
S$smarty->assien('commnumber', $commnumber); 
S$smarty->assien('commagoprice',$commagoprice): 
$smarty->assien('commfold'.$commfold): 
Ssmarty->assign('title'' 订 单 提交 成 功 "): 
$smarty->display(forminfo.tpl); 


模板 页 forminfo.tpl 包含 了 两 个 表格 ， 第 一 个 表格 显示 提交 订单 用 户 所 填 信 息 ; 第 二 个 表格 为 购买 


的 商品 信息 。 最 后 还 有 一 行 注意 文字 ， 提 醒 用 户 不 要 忘记 订单 号 。 如 果 有 条 件 ， 还 可 以 将 订单 打印 出 
来 。 模 板 页 商品 信息 代码 如 下 : 
<!-- 商品 信息 --> 


<table border="0" align="center" cellpadding="0" cellspacine="0"> 
<tr><td colspan="5"> 订 单 内 容 </td></tr> 
<tr><td> 商 品名 </td><td> 数 量 </td><td> 价 格 </td><td > 价格 折 率 </td><td> 合 计 </td></tr> 
{foreach key=key item=item from=$commname} 
<t> 
<td>{Sitem}</td><td>{Scommnumber[Skey]}</td> 
<td> {$commagoprice[$key]}&nbsp: 元 </td><td>{$commfold[Skey]}j&nbsp: 折 </td> 
<td>{$commagoprice[$key]*$commnumber[$key]}&nbsp: 元 </td> 
</t> 
{/foreach} 
<tr><td colspan="5"> 总 消费 {$formarr.total}&nbsp: 元 </td></tr></table> 
<p align="center"> 恭 喜 您 ! 订单 提交 成 功 。<br /> 请 您 在 一 周 内 按 您 的 支付 方式 进行 汇款 ,汇款 时 注 明 您 的 <font 
color="red"> 订 单 号 </font>! 汇 款 后 请 及 时 通知 我 们 </p> 
<p ><font color="red"> 注 意 ; </font> 请 记 住 <font color="red"> 订 单 号 </font>。 以 便 日 后 查询 及 有 疑问 时 使 用 。</p> 
<p align="center"><input type="button" value=" 我 要 打印 " onclick="window.print0" class="btn" /> </p> 


26.13.5 ”查询 订单 
订单 提交 后 ， 可 以 通过 导航 栏 中 的 “订单 查询 ” 超 链接 来 查看 订单 情况 。 查 询 关键 字 可 以 是 会 员 
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名 称 或 订单 号 ， 只 要 输入 一 项 就 可 以 。 单 击 “ 查 询 ” 按 钮 ， 将 会 在 页 面 下 方 显示 查询 结果 。 查 询 订单 
页 面 运行 结果 如 图 26.27 所 示 。 


查询 订单 
查询 用 户 。 fn 查询 订单 号 ，[ 查 河 
查询 结果 
可 畦 号 订 侦 会 员 。 改 贡 人。 订 曲 全 额 。。 付 歌 万 区 。 收 款 万 式 可 单 状态 
1209117958 tn E22 6666 银行 转 风 平邮 已 和 茹 
1209119797 pn T3325 报 行 转 峡 。。 平 皮 未 作 和 处理 
1241501476 人 放生 15294.6 ”邮局 汇款 ”快递 未 作 刘 理 


26.27 查询 订单 页 面 运行 结果 
本 模块 采用 Ajax 技术 , 对 查询 结果 在 本 页 进行 直接 输出 。 共 使 用 4 个 文件 : queryform.php、queryform. 


queryform.js 和 query.php。 
queryform.php 页 用 于 载 入 Smarty 配置 文件 ， 并 通过 display 方法 指定 queryform.tpl 模板 页 。 
queryform.tpl 包含 了 一 个 查询 表单 和 一 个 div 标签 ， 其 元 素 属 性 和 名 称 如 表 26.3 所 示 。 


表 26.3 ”查询 表单 元 素 和 div 标签 属性 及 说 明 


tpl、 


元 素 说 明 
查询 表单 ， 名 称 为 queryform 
会 员 查 询 文 本 框 
订单 号 查询 文本 框 


查询 按钮 ， 调 用 queryrst 函数 
用 于 显示 查询 结果 


通过 表 26.3 可 以 看 到 , 当 单 击 “ 查 询 ” 按 钮 时 , 将 触发 onclick 事件 , 调用 queryrst0 〇 函数。queryrstO 
函数 在 脚本 文件 js/queryform.js 内 。 该 文件 代码 如 下 : 


function queryrst(form) { 

入 ”获取 会 员 名 称 */ 

var name = form.name.value; 

族 ”获取 订单 号 */ 

var formid = form.formid.value: 

履 ”如 果 两 者 都 为 空 ， 则 弹出 警告 框 。 */ 

if(name —" && formid — "){ 
alert( 用 户 或 订单 号 至 少 有 一 个 不 能 为 空 ): 
form.name.focus(): 
Tetum false: 


} 
族 “将 获取 的 变量 传 给 query.php 页 */ 
var url = "query.php?vendee="+name+"&formid="+formid; 
xmlhttp.open("GET",url.true): 
庆 “调用 showfm0 函 数 */ 
xmlhttp.onreadystatechange = showfm: 
xmlhttp.send(nulD): 
} 
function showfmO{ 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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case 2:$tmp 二 ' 已 发 货 'break; 
case 3:$tmp 二 ' 已 收 货 ':break:; 
了 
Stmp = "</td></tr>"; 
} 
Stmp .= "</table>"; 
店 ”将 临时 变量 赋 给 Sreback 并 输出 
Sreback = $tmp: 


} 
echo Sreback:; 
?> 
有 关 电 子 商 务 平台 前 台 功 能 模块 的 讲解 到 此 结束 ， 接 下 来 讲解 后 台 管理 系统 中 首页 、 类 别管 理 和 
订单 管理 模块 的 设计 。 


26.14 后 台 首 页 设计 


铬 m 视频 讲解 ， 光盘 \TMNVideo\26\ 后 台 首页 设计 .exe 

后 台 管 理 系 统 对 网 站 的 商品 、 商 品类 别 、 会 员 及 公告 等 信息 进行 统一 管理 。 本 系统 的 后 台 主 要 包 
括 如 下 功能 模块 。 

回 ”类 别管 理 模块 : 主要 包括 对 商品 类 别 的 添加 、 修 改 及 删除 操作 。 

回 ”商品 管理 模块 : 主要 包括 对 商品 的 添加 、 修 改 、 删 除 及 订单 处 理 。 

回 用户 管理 模块 : 主要 包括 管理 员 管理 和 会 员 管理 。 其 中 ， 管 理 员 管 理 是 实现 对 管理 员 的 添加 、 

删除 和 修改 功能 ;会 员 管 理 则 包括 删除 和 冻结 功能 。 

回 ”公告 管理 模块 : 主要 包括 公告 的 添加 及 删除 操作 。 

回 ”链接 管理 模块 : 主要 包括 添加 、 修 改 和 删除 友情 链接 。 

后 台 首 页 的 运行 结果 如 图 26.28 所 示 。 


i 商城 - “A 


图 26.28 后 台 首 页 运行 结果 
26.14.1 后 台 首 页 布局 


后 台 首 页 和 前 台 首 页 不 同 ， 使 用 的 是 框架 布局 。main.php 页 的 框架 代码 如 下 : 
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<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<meta http-equiv="Content-Type" content="text/html: charset=gb2312" /> 
<link rel="stytlesheet" href="css/style.css" /> 
<title> 明 日 购物 商城 后 台 管理 系统 </title> 
</head> 
<!-- 使 用 frame 框架 布局 --> 
<frameset rows="113,*,100" cols="1004" frameborder="no" border="1" framespacine="0"> 
<!-- 头 部 框架 ， 命 名 为 topFrame， 载 入 文件 为 top.php --> 
<frame src="top.php" name="topFrame" scrolline="No" noresize="noresize" id="topFrame" title="topFrame" /> 
<frameset rows="*" cols="310,*" framespacing="0" frameborder="no" border="1"> 
<!--” 左 侧 框架 ， 名 字 为 leftFrame， 载 入 文件 为 left.php --> 
<frame src="leftphp" name="leftFrame” frameborder="0" scrolling="auto" noresize="noresize' 
id="leftFrame" title="leftFrame" /> 
<1-- ”中 部 框架 ， 名 字 为 mainFrame， 载 入 文件 是 default.php --> 
<frame src="default.php" name="mainFrame" id="mainFrame" title="mainFrame" /> 
</frameset> 
<1-- 底部 框架 ， 名 字 为 bottomFrame， 载 入 文件 是 bottom.php --> 
<frame src="bottom.php" name="bottomFrame" scrolling="No" noresize="noresize” id="bottomFrame" 
title="bottomFrame" /> 
</frameset> 
<noframes><body></body></noframes> 
</html> 


在 框架 页 中 包含 了 4 个 文件 ，top.php 为 后 台 页 面 的 标题 ，left.php 为 导航 栏 ，default.php 为 后 台 的 


功能 输出 页 面 ，bottom.php 为 网 站 的 尾 文 件 。 


26.14.2 ”DIV+JavaScript+CSS 实现 树 状 菜单 
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在 left.php 页 面 中 设计 了 一 个 树 状 菜单 ,是 应 用 DIV+JavaScript+CSS 来 实现 的 ,首先 来 看 div 标签 。 


<!-- 载 入 css 样式 和 javascript 脚本 --> 

<link href="css/left.css" rel="stylesheet" type="text/css" /> 

<script language="javascript" src="js/left.js"></script> 

<!-- 类别 管理 菜单 ， 注 意 加 粗 的 地 方 ”--> 

<div id="type" align="center" onclick="javascript:change(one,type):"> 类 别管 理 </div> 

<!-- 子 菜单 --> 

<div id="one" style="display: "> 

<div id="addtype" align="center"><a href="addtype.php" target="mainFrame" id="menu"> 添 加 类 别 </a></div> 
<div id="showtype" align="center"><a href="showtype.php" target="mainFrame" id="menu"> 查 看 类 别 </a></div> 
</div> 

<div id="hidediv" align="center"></div> 

<!-。 商品 管理 菜单 -> 

<div id="commo" align="center" onclick="javascript:change(two,type):"> 类 别管 理 </div> 

<div id="two" style="display:none"> 

<!-- 商品 管理 子 菜单 -> 


</div> 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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加 商品 的 类 别 。 当 选择 “一 级 类 别 ” 时 ， 下 面 的 “ 父 类 名 称 ” 则 不 可 选 。 添 加 类 别 页 面 的 运行 结果 如 
图 26.30 所 示 。 


日 购物 商城 的 


图 26.30 ”添加 类 别 页 面 的 运行 结果 
当 单 击 “ 添 加 类 别 ” 超 链接 时 ， 将 调用 addtype.php 页 。 该 页 从 数据 库 中 读 取 所 有 supid=0《〈 也 就 


一 级 类 别 ) 的 记录 ， 并 将 结果 集 直接 输出 为 下 拉 菜单 ， 传 递 给 模板 页 。addtype.php 页 的 代码 如 下 : 


<2php 
局 ” 载 入 数据 库 连接 文件 和 Smarty 模板 配置 文件 。*/ 
include_once 'config.php': 
include_once 'conn/conn.pl 
/#* ”生成 查询 语句， 下 所 有 supid-0 的 一 级 类 别 */ 
$sql = "select name,id from tb_class where supid = 0"; 
请 “执行 SQL 语句， 返回 结果 集 */ 
Srst = $conn->execute($sq]); 
/* ”将 结果 集 直 接 输出 为 下 拉 菜 单 ， 并 传递 给 模板 */ 
$smarty->assign('op'.$rst->GetMenu2("supid",".Sblank = false,".".'class="txt"")): 
$smarty->display(addtype.tpl): 

Ne 


模板 页 addtype.tpl 接受 op 下 拉 菜 单 后 ， 将 其 显示 在 “添加 商品 类 别 ” 表 单 中 。addtype.tpl 模板 代 


码 如 下 : 


602 


<!-- 载 入 js 脚本 文件 -一 
<script language="javascript" src="js/createxmlhttp.js"></script> 
<script language="javascript" src="js/chktype.js"></script> 
<table width="300" border="0" align="center" cellpadding="0" cellspacing="0"> 
<form id="addtype" name="addtype" method="post" action="#"> 
<tr><td colspan="2"> 添 加 商品 类 别 </td></tr> 
<tr><td > 类 别名 称 : </td><td><input name="names" type="text" id="names" class="txt"></td></tr> 
<tr><td > 类 别 等 级 : </td><td> 
<!-- ”类 别 等 级 下 拉 菜 单 ， 会 触发 onchange 事件 ， 调 用 changetype0 函 数 -> 
<select name="grade" OnChange= "changetype(addtype)" > 
<option value="1"> 一 级 类 别 </option> 
<option value="2" selected> 二 级 类 别 </option> 
</select> 
</td></t> 
<!-- 显示 op 变量 -> 
<tr><td> 父 级 名 称 : </td> <td>{$op}</td></tr> 
<tr><td colspan="2"><input type="button" value=" 添 加 " class="btn" onClick="chktype(addtype)"></td> 
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</u> 
</form> 
</table> 


该 模板 通过 “类 别 等 级 ”下 拉 菜 单 的 changetype0 函 数 来 控制 op 菜单 的 状态 。 如 果 添 加 的 是 一 级 
类 别 ， 则 op 菜单 不 可 用 ; 如 果 添 加 的 是 二 级 菜单 ， 则 op 菜单 可 用 。 当 用 户 输入 添加 类 别 后 ， 单 击 “ 添 
加 ”按钮 时 ， 会 调用 chktype0 函 数 。 包 含 这 两 个 函数 的 chktypejs 脚本 文件 的 代码 如 下 : 


必 ”控制 op 菜单 的 状态 
function changetype(form){ 


form.supid.disabled= 包 lse: 
}else{ 
form.supid.disabled=true; 


岂 
启 ”处 理 “ 类 别名 称 ”文本 框 wt 
function chktype(form){ 

Var name = form.names.value; 

Var supid = form.supid.value; 

SO 
alert(' 请 填写 类 别名 称 '): 
form.names.focus():; 

Tetum false; 


} 
族 ”根据 不 同 的 类 别 等 级 ， 生 成 不 同 的 url */ 
if(form.grade.value — "1"){ 
var url = "chktype.php?name="+name: 
}else{ 
var url = "chktype.php?name="+name+"&supid="+supid:; 


族 ”使 用 xmlhttp 对 象 打开 该 url， 并 调用 check 函数 处 理 返回 值 “*/ 
xmlhttp.open("GET",url.true): 
xmlhttp.onreadystatechange = check: 


xmilhttp.send(nul); 
} 
履 ”根据 返回 值 作出 相应 的 处 理 。 */ 
function checkO{ 


这 xmlhttp.readyState 一 4){ 
这 xmlhttp.status 一 200){ 

var msg = xmlhttp.responseText: 

imsg 一 "19{ 
alert( 类 名 重复 ): 

}else iftmsg — "2"){ 
alert( 添 加 失败 !"); 

}else{ 
alert( 添 加 成 功 ): 
location='showtype.php': 

DD 


在 chktypephp 处 理 页 实现 对 类 别 的 添加 ， 并 返回 不 同 的 参数 以 便 chktype0 函 数 进行 处 理 。 
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chktype.php 页 的 代码 如 下 : 
<2php 
include_once 'conn/conn .php': // 载 入 数据 库 连接 文件 
$name=S$_GET[mame']: /获取 类 别名 称 
($_GET['supid] = 二")?(Ssupid =0):(Ssupid =$_GET['supid]): /获取 类 别 等 级 
Sreback ="; // 设 置 返回 变量 
$sql = "select * from tb_class where name = '$name"™; // 声 明 SQL 语句 
Srst = $conn->execute($sql): // 返 回 查询 结果 集 
这 Srst->RecordCount0 — 1){ // 如 果 有 查询 结果 ， 说 明 类 别名 被 占用 
Sreback = "1'; 
yelse{ // 否 则 执行 添加 操作 


Sine = array0: 
Sine["name"] = $name: 
Sine["supid"] = $supid; 
S$intsql = $conn->GetInsertSQL(Srst, Sine); // 生 成 添加 语句 
if($conn->execute($intsql) 一 false){ 
Sreback = "2'; 
}else{ 
Sreback = '3' /如 果 成 功 ， 返 回 3 
入 
echo $reback: 


26.15.2 ”查看 类 别 


类 别 添加 成 功 后 ， 可 以 通过 “查看 类 别 ” 超 链接 来 修改 、 删 除 类 别 。 在 查看 商品 页 中 ， 类 别 按照 
父 类 1: 子 类 1、 子 类 2……; 父 类 2: 子 类 1、 子 类 2…… 的 格式 显示 。 修 改 类 别名 称 时 ， 直 接 在 对 应 
的 类 别 文本 框 中 输入 新 类 名 ， 然 后 单 击 对 应 的 “修改 ”按钮 即 可 。 删 除 时 则 直接 单 击 对 应 的 “删除 ” 
按钮 。 当 要 删除 的 父 类 包含 子 类 时 ， 则 不 允许 删除 父 类 。 查 看 类 别 页 面 的 运行 结果 如 图 26.31 所 示 。 


26.31 查看 类 别 页 面 运行 结果 


首先 来 介绍 showtype.php 页 。 该 页 执行 两 次 查询 ， 分 别 输出 一 级 类 别 和 二 级 类 别 的 数组 ， 传 递 给 
模板 页 。showtype.php 页 的 代码 如 下 : 


<2php 
include_once 'config php': // 载 入 Smarty 配置 文件 
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include_once 'conn/conn .php': // 载 入 数据 库 连 接 文 件 
Sbigsql = 'select idname from tb_class where supid = 0'; // 生 成 一 级 类 别 查 询 语句 
$smallsql = 'select * from tb_class where supid != 0'; // 生 成 二 级 类 别 查询 语句 
Sbigclass = $conn->execute($bigsql): // 返 回 一 级 类 别 结果 集 
$smallclass = $conn->execute($smallsq]):; // 返 回 二 级 类 别 结果 集 
Sbigarray = $bigclass->GetAssoc(): // 将 结果 集 输出 成 数组 类 型 
S$smallarray = $smallclass->GetAssoc(): 

S$smarty->assign('bigarray’, $bigarray); /将 数组 传递 给 模板 
S$smarty->assien('smallarray', $smallarray); 

$smarty->display('showtype.tpl"): 


?> 


showtype.tpl 模板 页 通过 赃 套 foreach 循环 ， 将 一 级 类 别 和 二 级 类 别 一 一 对 应 起 来 ， 并 输出 到 页 面 。 
showtype.tpl 页 的 代码 如 下 : 


<!-- 载 入 js 脚本 文件 --> 

<script language="javascript" src="js/createxmlhttp.js"></script> 
<script language="javascript" src="js/changetype.js"></script> 
<table> 

<!-- 省略 html 无 用 代码 --> 


<!-- “外 层 循环 ， 输 出 一 级 类 别 -> 
{foreach name=ftype key=fkey item=fitem from=$bigarray} 

<tr><td> 父 类 : 

<input id="moditype {$fkey}" name="moditype{Sfkey}" type="text" class="shorttxt" value="{S$fitem}" style="border- 
color:#996633:" /></td> 

<td> 
<input id = " modify " name = " modify " type = " button " value =" 修改 " onclick=" modifytype({$fkey}): "/> 
<input id = " delete " name = " delete " type = " button " value = "删除 " onclick = "delbigtype( {$fkey}):"> 
</td></tr> 

<!-- ”内 层 循环 ， 输 出 对 应 的 二 级 类 别 -> 

{foreach name = stype key = skey item = sitem from = $smallarray} 

{if $sitem[1] 一 $fkey} 

<tr><td> 子 类 : 

<input id="modtype {$skey}" name="moditype {$skey}" type="text" value=" {$sitem[0]}"/></td> 

<td><input id="modidfy" name="modify" type="button" value=" 修 改 " onclick=" modifytype( {$skey})"/> 
<input id="delete" name="delete" type="button" value=" 删 除 "onclick=" delsmalltype( {$skey})"> 
</td></tr> 
{请 

{/foreach} 
{/foreach} 
</form> 
</table> 


showtype.tpl 模板 中 包含 的 changetypejs 脚本 文件 主要 有 3 个 函数 : modifytype0、delbigtypeO0 和 
delsmalltype0， 分 别 控制 类 别 的 修改 和 删除 。 该 脚本 文件 的 代码 如 下 : 


睛 ”修改 类 别名 称 函数 。*/ 


function modifytype(key){ 
Var nm = "moditype'+key: 
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加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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<!-- 载 入 js 脚本 文件 -> 
<script laneuage="javascript" src="js/createxmlhttp.js"></script> 
<script language="javascript" src="js/shwform.js"></script> 
<table border="0" cellspacing="0" cellpadding="0" align="center"> 
<form id="shwfrm" name="shwfrm" method="post" action"#"> 
<tr> 


<!-- ”省略 部 分 为 要 显示 的 订单 信息 的 字段 名 --> 


<td> 订 单 状态 </td> 
<td> 处 理 </td> 
</t> 
{foreach key=key item=item from=$formarr} 
<t> 
<!-- ”省略 部 分 为 显示 的 订单 信息 --> 
<td> 
<!-- 根据 不 同 的 状态 值 ， 显 示 不 同 的 结果 --> 
{过 $item.state 一 0} 未 处 理 {elseif $item.state 一 1} 已 收 款 {elseif $item.state 一 2} 已 发 货 {elseif $item.state 一 3} 已 收 
货 {ff 
</td> 
<!-- 单 击 “ 请 求 处 理 ” 按 钮 ， 调 用 showme0 函 数 -> 
<td><input id="deal" name="deal" type="button" value=" 请 求 处 理 " onclick="showme( {$item.formid})" /> 
</td> 
</t> 
{/foreach} 
</form> 
</table> 
<!-- ”隐藏 的 表单 ，ID 为 chdl --> 
<div id="chdl" style="display:none:"> 
<table width="525" border="0" align="center" cellpadding="0" cellspacing="0"> 
<form id="changedeal" name="changedeal" method="post"> 
<tr><tdcolspan="6""> 订 单 处 理 </td></tr> 
<tr><td> 订 单 号 ;</td> 
<!--” 当 隐藏 表单 显示 时 ， 该 <div> 标 签 将 显示 被 激活 订单 的 formid --> 
<td><div id="formid">&nbsp:</div></td> 
<!-- 下 面 为 一 组 单 选 按钮 ， 它 们 有 着 相同 的 名 称 和 不 同 的 ID */ 
<td><input id="acceptmon" name="acceptsend" type="radio" value="1" checked="checked" 人 > 已 收 款 </td> 
<td><input id="sendwa" name="acceptsend" type="radio" value="2" /> 已 发 货 </td> 
<td><input id="acceptwa" name="acceptsend" type="radio" value="3" > 已 收 货 </td> 
<!-- 单 击 “ 修 改 ” 按 钮 ， 会 调用 changeme0 函 数 来 更 新 订单 状态 。--> 
<td><input id="chg" name="chg" type="button" value=" 修 改 " onclick="return changeme(changedeal)" /></td> 
</t> 
</form> 
</table> 
</div> 


在 该 页 中 所 调用 的 函数 都 包含 在 shwform.js 脚本 文件 中 。shwome0 函 数 的 作用 是 改变 id=chdl 的 
<div> 标 签 的 状态 ， 唯 一 的 参数 是 该 条 订单 的 订单 号 (formid) ， 并 在 id=formid 的 <div> 标 签 中 显示 出 
来 ; 另 一 个 函数 changeme0 的 作用 是 将 formid 值 和 被 选中 的 单 选 按钮 值 取出 并 传 给 changestate php 进 
行 处 理 ， 根 据 处 理 返 回 值 刷新 本 页 面 。shwform.js 页 面 的 主要 代码 如 下 : 
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卢 显示 /隐藏 表单 */ 
function showme(formid){ 
上 请 “判断 “ida-chdl” 的 <div> 标 签 的 样式 ， 如 果 是 显示 ， 则 改 为 隐藏 9/ 
这 document.getElementById(Cchdl).style.display 一 "){ 
document.getElementById(chdl).style.display = ‘none': 
/* ”否则 ， 将 该 标签 显示 出 来 ， 并 将 formid 显示 在 “id=formid” 的 <div> 标 签 中 。*/ 
}else{ 
document.getElementById(‘chdl").style.display = "; 
document.getElementById(formid').innerHTML = formid: 


} 
} 
刻 ”政变 状态 */ 
function changeme(form){ 


让 ”获取 formid */ 
Var fid = document.getElementById('formid').innerText:; 
Var lang = form.acceptsend.length: 
Var state; 
局 ”循环 查看 单 选 按钮 的 状态 ， 并 取得 被 选中 按钮 的 value 值 */ 
for(var i=0; i < lang; 计 +){ 

if(form.acceptsend[i].checked 一 true){ 

state = form.acceptsend[i].value: 


} 

1 

这 state 一 undefined){ 
alert(' 请 选择 处 理 项 ): 
Tetum false; 


中 
让 将 formid 和 state 值 传 给 changestatephp 页 */ 
Var url = "changestate.php?formid="+ 人 id+"&cstate="+state: 
证 “使 用 XMLHttpRequest 对 象 调 用 该 url *#/ 
xmilhttp.open("GET",url,true); 
上 请 对 返回 进行 处 理 响应 eh 
xmlhttp.onreadystatechange = functionO{ 

if(xmlhttp.readyState 一 4){ 

var msg = xmlhttp.responseText:; 


这 msg —'1){ 
location reload(): 
jelsef 
alert( 修 改 失败 +msg): 
人 
xmlhttp.send(nulD); 
最 后 的 changestate.php 负责 将 改变 的 记录 更 新 到 数据 表 中 。changestate.php 页 的 代码 如 下 : 
<?php 
include_once 'conn/conn.php': // 调 用 数据 库 连 接 文件 
Sformid = $_ GET[formid]: /获取 参数 值 
$state=$_GET[state]: 
Sreback = "0'; // 声 明 返 回 值 ， 初 始 化 为 0 
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Sarr = amay0: // 声 明 更 新 数组 

$sql = "select * from tb_form where formid = ".Sformid."": // 根 据 formid 生成 查询 语句 

Srst = $conn->execute($sq]): // 返 回 查询 结果 

if($rst->RecordCountO (= D{ /如 果 没 有 返回 值 ， 返 回 2 
Sreback = '2'; 

Jelse{ // 如 果 有 返回 值 
Sarr['state'] = $state: // 将 更 新 数据 存 到 数组 中 
S$UpdateSQL = $conn->GetUpdateSQL(Srst, $arr); // 生 成 更 新 语句 
这 false 一 $conn->execute($UpdateSQL)){ /执行 更 新 

Sreback = "3"; 
jelse{ 
Sreback ='1: /成 功 返 回 1 
入 
echo Sreback: // 输 出 返回 值 


?> 


26.17 开发 的 常见 问题 


仇视 频 讲解 :光盘 \TM\Video\26\ 开 发 的 常见 问题 .exe 
在 本 系统 开发 和 后 期 测试 的 过 程 中 , 开发 人 员 遇 到 了 各 种 各 样 的 疑难 问题 。 这 里 精 选 一 些 常见 的 、 
容易 被 忽略 的 问题 加 以 讲解 ， 希 望 可 以 为 初学 者 提供 一 些 帮 助 ， 在 开发 程序 时 少 走 一 些 弯 路 。 


26.17.1 解决 Ajax 的 乱码 问题 


问题 描述 : 当 使 用 Ajax 传递 数据 时 ， 要 么 在 数据 处 理 页 中 数据 不 能 被 正确 处 理 ， 要 么 输出 返回 值 
时 显示 无 法 识别 的 乱码 。 

解决 方法 : 这 是 因为 PHP 在 传递 数据 时 使 用 的 编码 默认 为 UTF-8， 造 成 了 非 英 文字 符 不 能 正确 传 
递 的 情况 。 解 决 方法 如 下 : 

在 所 有 的 PHP 页 中 都 输入 代码 : 

Header("Content-Type:text/html:charset=gb2312"); 


这 样 ， 所 有 的 页 面 即 可 正确 显示 。 


26.17.2 ”使 用 JS 脚本 获取 、 输 出 标签 内 容 


问题 描述 : 获取、 更 改 表单 元 素 值 和 特定 标签 内 容 。 

解决 方法 : 使 用 JS 脚本 获取 页 面 内 容 的 方式 主要 有 两 种 。 第 一 种 是 通过 表单 获取 表单 元 素 的 value 
值 。 格 式 为 : 

表单 名 称 .元 素 名 .value 


该 方式 只 能 获取 表单 中 的 元 素 值 ， 对 于 其 他 标签 元 素 则 无 能 为 力 。 而 第 二 种 方式 可 以 通过 ID 名 来 
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获取 页 面 中 任意 标签 的 内 容 : 
回 格式 1 


document.getElementById('id').value; 
回 格式 2 
document.getElementById(id).innerText: 


使 用 第 二 种 方式 时 要 注意 ， 标 签 的 ID 名 必须 存在 而 且 唯 一 ， 否 则 就 会 出 现 错误 。 向 标签 内 容 赋值 
时 ， 则 使 用 如 下 的 格式 : 
idinnerHTML = ' 要 显示 的 内 容 ' 


26.17.3 ”使 用 浮动 框架 做 关联 菜单 


问题 描述 ， 在 添加 商品 时 ， 商 品类 别 选 项 是 一 个 关联 菜单 。 在 不 刷新 本 页 的 前 提 下 实现 该 功能 十 
分 复杂 (当然 ， 如 果 使 用 了 ADODB 和 Ajax， 那 就 男 当 别 论 了 )〉。 

解决 方法 : 这 里 使 用 了 一 个 比较 灵活 的 方法 ， 就 是 使 用 浮动 框架 技术 ， 将 一 个 二 级 管理 菜单 放 到 
单独 的 一 个 网 页 中 ， 然 后 在 框架 中 显示 。 当 选择 不 同类 别 时 ， 菜 单 页 虽然 也 会 刷新 ， 但 整个 的 大 表单 
页 则 不 会 跟着 刷新 。 其 关键 代码 如 下 : 

<tr> 

<td> 商 品类 别 : </td> 

<td> 

<iframe id="menul" name="menul" src="menu.php”width="300" height="22" frameborder="0" scrolling="no" style= 

"margin-top:0px: margin-left: Opx: top:0px:;"></iframe> 

<input id="'stype" name="stype" type="hidden" value="" /> 

</td> 

</t> 


加 粗 的 代码 部 分 为 隐藏 表单 ， 保 存 当前 被 选择 的 类 别 ID。 添 加 商品 处 理 页 就 是 从 这 个 隐藏 表单 中 
获取 商品 类 别 的 。 
26.17.4 ”禁用 页 面 缓存 


问题 描述 :使 用 Ajax 技术 可 以 防止 页 面 刷 新 ， 但 有 时 也 会 产生 新 的 问题 。 例 如 ， 在 “会 员 管理 ” 
页 面 中 ， 如 果 连 续 “ 冻 结 ” 和 “解冻 ”会 员 ， 超 过 3 次 后 ， 该 功能 就 会 失效 。 因 为 在 一 定时 间 内 ， 如 
果 做 相同 的 操作 ， 那 么 XMLHttpRequest 对 象 会 执行 缓存 里 有 的 页 面 ， 从 而 造成 操作 失败 。 

解决 办 法 : 使 用 header0 函 数 将 缓存 关闭 。 使 用 如 下 语句 : 


header("CACHE-CONTROL:NO-CACHE"): 


将 这 句 代码 添加 到 XMLHttpRequest 对 象 所 调用 的 处 理 页 的 顶部 即 可 。 
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自 定义 函数 判断 上 传 文件 的 后 级 。 


解决 方法 : 创建 自 定义 函数 。f postfix0 函 数 的 代码 如 下 : 


让 
* 判 断 文 件 后 缀 
*Sf type: 允许 文件 的 后 缀 类 型 (数组 ) 
*Sf upfiles: 上 传 文件 名 
function f postfix($f type.$f upfiles){ 
Sis_pass = false: 
Stmp_upfiles = split("\.",$f upfiles): 
Stmp_num = count($tmp_upfiles); 
这 in_array(strtolower($tmp_upfiles[Stmp num - 1]).Sf type)) 
$is_pass = S$tmp_upfiles[Stmp_num - 1]; 
return $is_pass: 


26.18 ”网 站 运行 错 1i 


铬 m 视频 讲解 ， 光 盘 \TMNVideo\26\ 网 站 运行 错误 分 析 .exe 


/使 用 split0 函 数 分 割 文件 
/查找 文件 后 绥 

// 判 断后 缀 是否 在 允许 列表 内 

// 如 果 是 ， 则 将 后 级 名 赋 给 变量 
/返回 变量 


电子 商务 平台 开发 完成 ， 测 试 成 功 后 即 可 投入 使 用 ， 但 是 将 程序 上 传 到 服务 器 、 或 者 复制 到 其 他 
机 器 中 运行 时 ， 却 又 出 现 了 一 些 错误 。 下 面 将 分 析 在 这 种 情况 下 出 现 错误 的 原因 以 及 解决 方法 。 


26.18.1 数据 库 导致 的 错误 


在 运行 本 系统 时 ， 由 于 没有 附加 数据 库 或 者 数据 库 的 用 户 名 和 密码 不 正确 ， 会 出 现 如 图 26.33 和 


图 26.34 所 示 的 错误 信息 。 


提示 “connection 
error”， 表 示 没 有 
找到 数据 库 
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MySQL 数据 库 的 用 


户 名 和 密码 不 正确 
导致 的 错误 


图 26.33 没有 附加 MySQL 数据 库 导 致 的 错误 图 26.34 MySQL 数据 库 用 户 名 和 密码 不 正确 导致 的 错误 
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解决 方法 如 下 : 
(1) 从 本 系统 中 的 26/data 文件 夹 下 复制 本 系统 的 数据 库 ， 附 加 到 本 机 MySQL 数据 库 的 data 文 


件 夹 下 。 
(2) 如 果 MySQL 数据 库 的 用 户 名 和 密码 与 本 系统 所 使 用 的 用 户 名 和 密码 不 一 致 ， 有 如 下 两 种 解 


决 方案 。 
加 ”第 一 种 ,修改 本 系统 的 数据 库 连接 文件 ， 找 到 conn 文件 夹 下 的 conn.php 文件 ， 修 改 其 中 的 用 
户 名 和 密码 ， 使 其 与 本 机 MySQL 数据 库 的 用 户 名 和 密码 一 致 。conn.php 文件 的 代码 如 下 : 


<2php 
include_once (‘inc/char.php’); 
include_once ("adodb5/adodb.inc.php"): 
$conn = ADONewConnection('mysql'): 
$conn->PConnect('localhost','root','root',db_database26") or die(connection error’); 
$conn->Execute('set names gb2312"): 
$ADODB FETCH MODE = ADODB FETCH BOTH: 


?> 
本 系统 中 MySQL 数据 库 的 用 户 名 为 root， 密 码 为 root， 数 据 库 名 称 为 db_database26。 


< 注意 : 如 果 要 修改 本 系统 连接 MySQL 数据 库 的 用 户 名 和 密码 ， 需 要 修改 两 个 conn.php 文件 ， 一 个 
在 26/conmn 文件 夹 下 ， 男 一 个 在 26/admin/conn 文件 夹 下 。 


加 ”第 二 种 ， 修 改 本 机 MySQL 数据 库 的 用 户 名 和 密码 ， 该 操作 可 以 通过 phpMyAdmin 图 形 化 管 
理工 具 来 完成 ， 具 体操 作 方法 可 以 参考 本 书 第 18 章 的 实战 。 


26.18.2 Smarty 模板 的 配置 错误 


由 于 本 系统 是 应 用 Smarty 模板 进行 开发 的 ， 所 以 在 运行 本 系统 时 需要 对 Smarty 模板 进行 配置 ， 
如 果 没 有 正确 指定 Smarty 类 库 的 位 置 或 者 Smarty 类 库 不 存在 ， 将 出 现 如 图 26.35 所 示 的 错误 。 


在 指定 的 位 置 中 没有 获取 到 包含 文件 Smarty.class.php; 错误 出 现在 config.php 的 第 7 行 


Varning: require(F:/MppServ/ww\sl\26\Snarty\Snarty. class. php) [function. require]: 


failed to open strean: No such file or directory in F:\AppServ\vwr\ta\sl\26\config. php on line 了 


Fatal error: require() lfunction. require): 
Failed opening required “F:/AppServ/we\s1\26\Snarty\Snarty. class. php’ (include_path=". ;C:\php5\pear’) in 


F:\AppServ\vww\ta\sl\26\config. php on line 7 


在 F:AppServiwww\sl\26\Smarty 文件 夹 下 没有 找到 文件 Smarty.class.php 


图 26.35 配置 Smarty 的 路 径 不 正确 
上 述 错 误 出 现在 本 系统 的 config.php 文件 的 第 7 行 ， 即 在 指定 的 路 径 下 没有 找到 Smarty.class.php 
文件 。 
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修改 这 个 错误 之 前 ， 首 先 要 明确 几 个 目录 在 用 户 机 器 上 的 位 置 : 
回 ”确定 用 户 计算 机 上 Apache 服务 器 的 根 目录 〈 即 PHP 程序 运行 文件 夹 ) 。 
加 ”确定 本 系统 在 Apache 服务 器 根 目 录 下 的 位 置 。 
回 ”确定 Smarty.classphp 文件 在 本 系统 中 的 位 置 。 
在 明确 了 这 3 个 目录 之 后 ， 再 来 修改 这 个 错误 信息 : 
加 ”确定 Apache 服务 器 根 目 录 “F:\AppServwwww”。 
回 ”确定 本 系统 在 服务 器 下 的 位 置 “vtmvslh\”。 
加 ”确定 Smarty.class.php 文件 在 本 系统 中 的 位 置 “26\Smarty\Smarty.class php”。 
确定 了 上 述 3 个 目录 以 后 ,该 错误 即 修改 完成 .在 “F:\AppServwww\tm\s1\26 ”文件 夹 下 打开 congfig. 
php 文件 ， 锁 定 第 7 行 的 内 容 ， 其 中 常量 BASE PATH 指定 的 是 服务 器 的 根 目录 ， 没 有 任何 问题 ， 错 
误 出 现在 常量 SMARTY PATH 指定 的 Smarty 类 库 文件 的 绝对 路 径 上 ， 图 26.35 所 示 指 定 Smarty 类 库 
文件 的 绝对 路 径 是 “\sl\26\Smarty\”， 而 实际 的 绝对 路 径 应 该 是 “\tmsl\26\Smarty\”。config.php 的 
正确 代码 如 下 : 
<?php 
局” 定义 服务 器 的 绝对 路 径 */ 
define(BASE PATH'.S$_SERVER[DOCUMENT ROOT): // 获 取 服 务 器 的 根 目录 D:/AppServ/www 
谨 ”定义 Smarty 目录 的 绝对 路 径 */ 
define('SMARTY_PATH',\tm\sI2@\Smarty\W); /指定 Smarty.class.php 文件 在 这 个 服务 器 中 的 实际 位 置 
人 # 加 载 Smarty 类 库 文件 */ 
Tequire BASE PATH.SMARTY PATH.Smarty.class.php': 
上 # 实例 化 一 个 Smarty 对 象 所 
$smarty = new Smarty; 
族 ”定义 各 个 目录 的 路 径 所 
$smarty->template dir =BASE PATH.SMARTY PATH.'templates/: 
$smarty->compile dir= BASE PATH.SMARTY PATH .templates c/'; 
$smarty->config dir=BASE PATH.SMARTY PATH.configs/: 
S$smarty->cache_dir =BASE PATH.SMARTY PATH.cache/': 
?> 


< 注意 : 在 本 系统 中 有 两 个 config.php 文件 ， 一 个 直接 存储 在 26/ 文 件 夹 下 ， 田 一 个 是 后 台 管 理 系 统 
的 config.php 文件 ， 存 储 在 26/admin/ 文 件 夹 下 。 如 果 要 修改 Smarty 类 库 文件 的 绝对 路 径 ， 
这 两 个 文件 都 要 修改 。 


26.19 本 章 小 结 


本 章 使 用 Smarty、ADODB、Ajax 等 目前 的 主流 技术 实现 了 一 个 电子 商务 平台 。 其 中 , 应 用 Smarty 
模板 实现 网 站 的 动静 分 离 , 通过 ADODB 操作 MySQL 数据 库 , 通过 Ajax 实现 无 刷新 验证 ,通过 DIV、 
JavaScript 和 CSS 实现 树 状 导航 菜单 , 并 且 对 在 开发 过 程 中 出 现 的 疑难 问题 进行 了 总 结 。 和 希望 读者 能 
过 这 个 项 目 实例 ， 将 本 书 前 面 章节 中 讲解 的 内 容 融 会 贯通 ， 掌 握 网 络 开发 的 整体 操作 流程 。 
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办 公 自 动 化 系统 


办 公 自 动 化 英文 原 称 Office Automation, 缩写 为 OA， 办公 自动 化 系统 即 能 实 
现 办 公 室 内 事务 性 业务 的 自动 化 。 

办 公 自 动 化 没有 明确 的 定义 ,最 普遍 的 说 法 是 : 凡是 在 传统 的 办 公 室 中 采用 各 
种 新 技术 、 新 机 器 、 新 设备 从 事 办 公 上 业务 ， 都 属于 办 公 自 动 化 的 领域 。 

办 公 自 动 化 系统 与 办 公 室 自动 化 在 概念 上 存在 一 定 的 差别 。 办 公 自 动 化 通常 指 
办 公 室 中 配备 具有 自动 化 功能 的 设备 , 这 些 设 备 能 实现 某 些 办 公 活 动 自动 化 或 某 个 
单位 业务 的 自动 化 处 理 ; 而 办 公 自 动 化 系统 则 是 在 办 公 室 自动 化 功能 的 基础 上 发 展 
起 来 ， 以 办 公 自 动 化 技术 为 主体 ， 同 人 、 组 织 、 制 度 、 环 境 等 相 结合 的 完整 的 系统 。 

通过 阅读 本 章 ， 可 以 学 习 到 : 

由 办公 自 动 化 管理 系统 的 开发 流程 

MW” 进一步 学 习 如 何 做 项 目 需求 分 析 与 系统 设计 

MW 页 面 布 局 中 的 框架 布局 

使 用 递 娄 图 数 做 多 级 下 拉 菜 单 

MW 系统 日 志 的 实现 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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添 | | 修 | | 出 
加 | | 改 | | 除 
部 | | 部 | | 部 
门 | ID 


账号 权限 
[用 户 组 设置 | 
权限 分 配 


27.2 办公 自 动 化 后 台 管理 系统 


27.2 技术 准备 


在 开发 办 公 自 动 化 管理 系统 平台 时 ， 该 项 目 所 使 用 的 软件 及 开发 环境 如 下 。 
加 ”服务 器 端 
> 操作 系统 Windows 2003 Server/Linux (推荐 ) 。 
服务 器 : Apache 2.2。 
PHP 软件 : PHP 5.1.6。 
数据 库 : MySQL 5.0.24。 
MySQL 图 形 化 管理 软件 : phpMyAdmin-2.9.0.2。 
开发 工具 : Dreamweaver 8。 
浏览 器 : IE 6.0 及 以 上 版 本 。 
分 辨 率 : 最 佳 效果 1024X768 像素 。 
回 “客户 端 
> 浏览 器 : 正 6.0 及 以 上 版 本 。 
> “分辨 率 : 最 佳 效果 1024X768 像素 。 


Vvvyvyv 


A 


系统 日 志 


数据 备份 


修改 密码 
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27.3 开发 过 程 


27.3.1 数据 库 设计 


本 系统 使 用 MySQL 数据 库 ， 用 户 名 为 root， 密 码 为 rocot， 数 据 库 名 称 为 db_database27。 本 数据 库 
主要 包含 13 个 数据 表 ， 如 图 27.3 所 示 。 


加 服务 器 :localhost ， 司 数据 库 : db_database27 
表 5 要 四 
company Mysy nese_d 全 训 风 衣 
四 eortrober MySAY od 
teart NrSAY i 
gop Ms PB 
is MO En 
st Wa 2 
mw Mea 可 上 和 列表 
toporson MO 全 
plan MrSAM 号 2313_cnnese_ol 计划 机 
人 regater 。 NSAM 下 2312_rhineae_o 等 让 
四 sg NSAM gb2313_chinesw_5 罗列 家 
superson MYSAY P2312_:hnoso_pl 全 和 用 了 二 
esers 。 MAOAY。 风 2312_thinese_ci 用 P9 表 


图 27.3 db _database27 数据 库 中 的 数据 表 
27.3.2 前台 首 页 设计 


前 台 主 要 是 员工 操作 页 面 ， 其 功能 的 使 用 权限 由 后 台 管理 员 进 行 分 配 。 前 台 首 页 页 面 如 图 27.4 所 
示 ， 主 要 显示 企业 公告 信息 、 活 动 安排 信息 、 个 人 计划 信息 及 审核 批示 信息 ， 此 处 的 “个 人 计划 ”和 
“审核 批示 ”只 显示 当前 员工 的 计划 和 批示 情况 ， 在 “任务 绩效 ”、“ 质 量 绩效 ”及 “批示 审核 ”页 
面 中 可 对 所 有 员工 信息 进行 查询 。 


一 -一 一 


三 小 公 自 动 化 管理 系统 


图 27.4 前 台 首页 页 面 


(1) 企业 信息 

通过 “企业 管理 ”页 面 可 对 “公司 简介 ”进行 修改 ， 进 行 “ 规 章 制度 ”的 添加 、 修 改 及 删除 。 

〈2) 个 人 计划 

通过 “个 人 计划 ”中 的 各 页 面 可 以 添加 工作 反馈 、 周 计划 、 月 计划 、 年 计划 及 任务 计划 。 
2 
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(3) 企业 绩效 

通过 “任务 绩效 ”页 面 可 查看 及 删除 所 有 员工 的 年 计划 和 任务 计划 ， 通 过 “质量 绩效 ”页 面 可 查 
看 周 计划 、 月 计划 及 工作 反馈 信息 。 

(4) 人 事 消 息 

通过 “消息 管理 ”页 面 可 对 公告 信息 及 活动 安排 信息 进行 发 布 、 修 改 及 删除 。 

(5) 审核 批示 

在 “发 布 审核 ”页 面 中 可 以 发 布 、 修 改 及 删除 审核 信息 ， 在 “批示 审核 ”页 面 中 可 审批 及 删除 审 
核 信 息 。 

(6) 考勤 管理 

通过 “上 下 班 登记 ”、“ 病 事假 登记 ”、“ 加 班 登录 ”页 面 可 添加 签到 时 间 ， 通 过 “考勤 记录 ” 
页 面 可 设置 考勤 时 间 、 查 看 及 删除 员工 的 考勤 记录 。 

(7) 职员 天 地 

在 “职员 浏览 ”页 面 中 可 以 查看 员工 信息 ; 在 “个 人 设 定 ”页 面 中 可 修改 个 人 资料 ，“ 意 见 箱 ” 
只 有 部 门 为 “人 事 部 ”的 员工 可 以 进行 回复 及 删除 ， 其 余 用 户 只 可 以 发 表意 见 。 


27.3.3 ”人 事 消息 模块 设计 


人 事 消息 模块 主要 是 对 文件 的 收发 进行 管理 。 模 块 的 设计 和 实现 并 不 是 十 分 复杂 ， 但 在 整个 系统 
中 的 位 置 却 很 重要 。 因 为 公告 栏 和 意见 箱 面向 的 是 全 体 用 户 ， 企 业 的 最 新 动向 和 职员 的 意见 首先 都 是 
在 这 里 体现 出 来 的 。 

人 事 消息 模块 主要 包含 两 部 分 内 容 ， 一 部 分 是 面向 全 体 用 户 的 ， 包 括 查 看 公告 、 活 动 、 意 见 箱 等 ; 
一 部 分 是 仅 对 人 事 部 开放 ， 其 他 用 户 不 允许 、 也 不 会 看 到 的 页 面 ， 如 公告 管理 、 意 见 管理 等 。 人 事 消 
息 用 例 图 如 图 27.5 所 示 。 


回复 留 言 ) < 太一 DC) 局、 
发 布 \ 告 ) 全 /一 少 (Di 人 
超级 用 户 ! ! 普通 用 户 


图 27.5 人 事 消息 用 例 图 
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27.3.4 ”考勤 管理 模块 设计 


考勤 功能 是 办 公 自 动 化 管理 系统 中 每 天 都 要 使 用 到 的 功能 模块 ， 也 是 比较 重要 的 模块 之 一 ， 除 了 
包括 正常 的 上 下 班 登记 功能 外 ， 还 要 包含 病 事假 登记 和 加 班 登记 等 特殊 登记 功能 。 管 理 员 通过 考勤 记 
录 实 现 对 上 下 班 及 加 班 标准 时 间 的 设置 。 

考勤 模块 主要 的 功能 如 下 。 

回 上 下 班 登记 : 包括 上 班 登记 和 下 班 登记 。 

回 ” 病 事假 登记 : 包括 病假 登记 和 事假 登记 。 

回 “加班 登 记 : 包括 加 班 上 班 登记 和 加 班 下 班 登记 。 

回 ”考勤 记录 : 包括 上 下 班 标准 时 间 设 置 和 加 班 标准 时 间 设 置 。 

考勤 模块 的 活动 图 如 图 27.6 所 示 。 


上 下 班 登记 病 事假 登记 


加 班 上 班 登记 加 班 下 班 登记 
让 让 2 else | else 这 C >else 


迟到 整 点 


© 


27.6 考勤 模块 活动 图 
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27.3.5 ”后 台 首 页 设计 


在 下 地 址 栏 中 输入 “http:/127.0.0.l/tm/sy27/admin/”， 即 可 访问 办 公 自 动 化 系统 的 后 台 登 录 页 面 。 
后 台 操作 页 面 如 图 27.7 所 示 。 后 台 主要 对 部 门 信息 、 职 员 信息 、 用 户 权限 及 数据 库 等 信息 进行 管理 。 


而 公 自 动 化 
FEL 


J a 中 

es 而 计划 日 站 
E 1 

0 系 缠 E 志 在 天 | o 1 
3 二 1 

和 一 了 和 RI 0 闫 驶 

3 禄 到 审 的 写 见 袜 试 阁员 工 正式 员工 ,部 [ 斌 再, 吕 斌 理 ，。 葵 吉 

个 人 设 定 0 其 六 

请 站 计 定 画 门 可 奸 , 总 经 理 Ld 


图 27.7 后 台 操作 页 面 

回 “部门 管 理 ; 实现 部 门 信息 的 查看 、 修 改 和 删除 。 

回 ”职员 管理 : 实现 职员 信息 的 查看 、 修 改 和 删除 。 

回 ”权限 管理 : 设置 账号 的 权限 ;控制 用 户 属于 哪个 用 户 组 ; 控制 权限 的 分 配 。 

< 注意 : 当 功 能 没有 被 指定 操作 权限 组 时 (就 是 “开放 组 ”状态 为 0 时， 如 图 27.8 所 示 )， 则 该 功能 

默认 可 被 所 有 权限 组 操作 ， 如 图 27.9 所 示 。 但 如 果 该 功能 被 指定 操作 权限 组 ， 则 其 余 权 限 
组 将 无 权 操作 。 而 且 当 新 添加 权限 组 时 ， 该 功能 默认 为 拒绝 操作 状态 ， 如 图 27.10 所 示 ， 如 
果 启 用 则 需要 重新 添加 组 。 


效 详 访问 组 


图 27.9 权限 分 配 图 27.10 权限 分 配 
回 ”系统 管理 : 管理 系统 日 志 ， 备 份 数据 和 修改 管理 员 密 码 。 


27.3.6 部门 管理 模块 设计 


一 个 成 熟 、 稳 定 的 企业 ， 一 定 要 有 一 个 合理 的 部 门 结构 ， 包 括 每 个 部 门 需要 做 什么 工作 、 部 门 之 
间 的 协调 关系 以 及 部 门 之 间 的 上 下 级 关系 等 都 要 明确 下 来 ， 这 样 才能 使 各 部 门 各 尽 其 职 ， 不 会 出 现 资 


a 
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源 浪费 ， 提 高 企业 整体 的 效率 。 本 系统 中 部 门 管理 模块 包括 两 大 部 分 : 

回 查看 部 门 

查看 各 个 部 门 名 称 和 部 门 之 间 的 上 下 级 关系 ， 还 可 以 对 部 门 的 信息 和 级 别 进行 修改 ， 如 果 是 最 底 
层 的 部 门 ， 则 可 以 对 其 进行 删除 操作 。 

加 ”添加 部 门 

可 以 添加 新 的 部 门 ， 包 括 部 门 名 称 、 上 级 部 门 和 部 门 备注 。 

部 门 管理 操作 流程 图 如 图 27.11 所 示 。 


退 到 登录 界面 


判断 是 否 为 管理 员 


二 
r 一 一 一 一 是 疝 | 添加 部 门 |e 
复 
到 也 部 门 名 容 
修改 部 门 | | 
修改 失败 IE 7 
修改 成 功 删除 成 功 


图 27.11 部 门 管理 操作 流程 图 
27.4 本 章 小 结 


本 章 通过 一 个 完整 的 办 公 自 动 化 管理 系统 开发 过 程 ， 向 读者 讲述 了 系统 开发 的 几 个 重要 环节 ， 还 
包括 了 几 个 主要 模块 的 功能 实现 ， 最 后 着 重 讲 解 了 MySQL 备份 的 相关 知识 。 相 信 通 过 本 章 的 学 习 ， 
读者 对 如 何 开发 一 个 真实 的 项 目 会 有 进一步 的 了 解 ， 通 过 自己 动手 实践 ， 完 成 一 个 功能 相似 的 办 公 自 
动 化 管理 系统 是 完全 不 成 问题 的 。 


[如 说 明 : 由 于 篇 幅 所 限 ， 本 章 只 对 办 公 自 动 化 系统 的 模块 进行 了 简单 介绍 ， 关 于 办 公 自 动 化 系统 的 
详细 代码 可 参见 本 书 附带 光盘 。 
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在 全 球 知 识 经 济 和 信息 化 高 速 发 展 的 今天 ， 信 息 化 是 决定 企业 成 败 的 关键 因 
素 , 企业 需要 在 网 站 上 发 布 供求 信息 , 才能 在 同 领域 的 竞争 中 得 到 突飞猛进 的 发 展 。 
一 个 广泛 、 快 速 、 自 由 的 信息 交流 平台 ， 为 用 户 带 来 方便 的 同时 ， 也 会 给 企业 
带 来 无 限 的 商机 。 于 是 ,以 因 将 网 为 基础 的 信息 交流 平台 的 易 查 供求 信息 网 出 现 了 。 
易 查 供求 信息 网 致力 于 优化 信息 交流 ， 实 现 信息 的 快速 交流 。 
在 本 系统 中 应 用 到 的 关键 技术 和 方法 如 下 : 
使 当前 窗口 承载 框架 页 中 的 起 链接 页 面 
自动 计算 以 系统 日 期 为 基数 的 相对 日 期 
do…while 循环 语句 
查询 关键 字 描 红 
框架 技术 在 Web 网 站 中 的 应 用 
表单 数据 的 两 种 提交 方式 
通过 MySQI 图 数 连 接 、 操 作 数据 库 
通过 SQL 语句 实现 数据 的 查询 、 更 新 、 修 改 和 删除 操作 


总 于 于 于 至 于 于 至 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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回 ”服务 器 端 


服务 器 : Apache 2.2。 
PHP 软件 : PHP 5.1.6。 
数据 库 : MySQL 5.0.24。 
MySQL 图 形 化 管理 软件 : phpMyAdmin-2.9.0.2。 
开发 工具 : Dreamweaver 8。 
浏览 器 : IE 6.0 及 以 上 版 本 。 
分 辨 率 : 最 佳 效果 1024X768 像素 。 
回 ”客户 端 
> 浏览 器 : 正 6.0 及 以 上 版 本 。 
> ”分辩 率 : 最 佳 效 果 1024X768 像素 。 


Vvvvvyvyvyv 


28.3 开发 过 秆 


28.3.1 数据 库 设 计 


操作 系统 : Windows 2003 ServerLinux (推荐 ) 。 


品 
站 滑 


本 系统 是 一 个 中 小 型 的 供求 信息 平台 ， 但 是 由 于 平台 会 涉及 海量 数据 ， 因 此 需要 充分 考虑 到 成 本 问 


题 及 用 于 需求 〈 如 跨 平 台 ) 等 问题 ， 而 MySQL 是 世界 上 最 为 
流行 的 开放 源码 的 数据 库 ， 是 完全 网 络 化 的 跨 平台 的 关系 型 数 
据 库 系统 ， 这 正好 满足 了 中 小 型 企业 的 需求 ， 所 以 本 系统 采用 
MySQL 数据 库 。 

结合 实际 情况 及 对 用 户 需 求 的 分 析 ， 供 求 信息 网 中 应 用 
的 db_database28 数据 库 主 要 包含 4 个 数据 表 , 如 图 28.3 所 示 。 


28.3.2 ”前 台 功 能 设计 


加 服务 器 :localhost ， 品 数据 库 : db_database28 
束 类 型 整理 


th_odmin MyiSAM 
th_acvertising MyISAW 
tb_info MyISAM 
由 beaguerinfo MyisAM 


图 28.3 


号 2312_chinese_cl 。 党 理 员 信 息 表 

名 2312_chinese_ci 。 企业 广 肖 信息 表 
后 2312_ehinese_cl 。 免费 类 求 信息 表 
二 2312_thinese_cl 。 付费 供求 信息 表 


易 查 供求 信息 网 数据 表 


网 站 前 台 关 乎 着 网 站 的 建设 及 形象 宣传 ， 它 对 网 站 生存 和 发 展 起 着 非常 重要 的 作用 。 网 站 前 台 应 
该 是 一 个 信息 含量 较 高 、 内 容 较 丰 富 的 宣传 平台 。 供 求 信息 网 前 台 主要 包含 以 下 内 容 : 

回 ”网 站 菜单 导航 《包括 公寓 信息 、 招 聘 信 息 、 求 职 信息 、 培 训 信息 、 家 教 信 息 、 房 屋 信息 、 车 
辆 信息 、 求 购 信息 、 出 售 信息 、 招 商 引资 、 寻 人 / 物 启示 等 ) 。 

回 ”发 布 免费 的 供求 信息 〈 包 括 公寓 信息 、 招 聘 信息 、 求 职 信息 、 培 训 信息 、 家 教 信息 、 房 屋 信 
息 、 车 辆 信息 、 求 购 信息 、 出 售 信息 、 招 商 引 资 、 寻 人 / 物 启示 等 ) 。 

回 ”推荐 供求 信息 显示 〈 包 括 公寓 信息 、 招 聘 信息 、 求 职 信息 、 培 训 信息 、 家 教 信息 、 房 屋 信息 、 
车 辆 信息 、 求 购 信 息 、 出 售 信息 、 招 商 引资 、 寻 人 / 物 启示 等 ) ， 其 中 ， 付 费 信息 按时 间 顺 序 


降序 排列 ， 免 费 信息 按时 间 顺 序 分 页 显示 。 
回 ”显示 推荐 的 企业 广告 信息 。 
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回 ”供求 信息 快速 检索 ， 支 持 模糊 查询 和 查询 关键 字 描 红 功 能 。 
回 后台 登录 入 口 ， 为 管理 员 进 入 后 台 提供 一 个 入 口 。 
前 台 功 能 结构 如 图 28.4 所 示 。 


图 28.4 ”供求 信息 网 前 台 功 能 结构 图 
28.3.3 ”免费 供求 信息 发 布 模块 设计 


免费 供求 信息 发 布 提供 对 象 为 供求 信息 用 户 ， 是 供求 信息 网 站 非常 重要 的 功能 ， 也 是 供求 信息 网 
站 的 核心 功能 。 

免费 供求 信息 发 布 模块 可 以 完成 11 种 不 同类 别 信息 的 发 布 。 用 户 可 以 根据 自身 需要 将 供求 信息 发 
布 到 相应 的 信息 类 别 中 〈 公 寓 信 息 、 招 聘 信息 、 求 职 信息 、 培 训 信息 、 家 教 信息 、 房 屋 信息 、 车 辆 信 
息 、 求 购 信息 、 出 售 信息 、 招 商 引 资 、 寻 人 / 物 启示 ) 。 信 息 发 布 成 功 后， 需要 管理 员 进 行 审核 ， 只 有 
审核 成 功 的 信息 才能 显示 在 前 台 相 应 的 信息 类 别 网 页 中 。 免 费 供求 信息 发 布 的 流程 如 图 28.5 所 示 。 


图 28.5 免费 供求 信息 发 布 流程 图 
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功能 创建 成 功 后 ， 用 户 通 过 单 击 前 台 页 面 导航 栏 的 “我 要 发 布 ” 超 链接 ， 进 入 信息 发 布 页 面 ， 如 
图 28.6 所 示 。 程序 会 先 来 验证 用 户 是 否 输入 信息 ， 若 验证 失败 ， 则 返回 信息 发 布 页 面 ,进行 相应 提示 。 
车 验证 成 功 ， 则 向 数据 库 中 插入 记录 ， 完 成 发 布 操作 。 


图 28.6 免费 供求 信息 发 布 网 页 
28.3.4 ”信息 检索 模块 设计 


信息 检索 是 对 已 存在 于 数据 库 中 的 数据 按 条 件 进 行 筛 选 浏览 ， 是 查看 历史 信息 和 确认 数据 操作 最 
为 快速 、 有 效 的 办 法 。 信 息 检索 模块 主要 通过 选择 信息 类 型 和 输出 查询 关键 字模 糊 查 询 供求 信息 资源 ， 
并 输出 查询 结果 。 考 虑 到 供求 信息 的 信息 量 较 大 ， 本 模块 对 与 查询 关键 字 相 匹配 的 查询 结果 进行 描 红 ， 
从 而 方便 用 户 的 浏览 。 信 息 检 索 模块 示意 图 如 图 28.7 所 示 。 


针 


输出 查询 结果 
查询 关键 宇 描 红 


28.7 ”信息 检索 模块 示意 图 
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在 开发 信息 检索 模块 时 ， 由 于 该 网 站 含有 大 量 的 数据 信息 ， 为 了 方便 用 户 浏览 网 站 信息 ， 需 要 添 
加 复合 条 件 查询 实现 搜索 功能 。 在 信息 检索 区 的 “关键 字 ” 文 本 框 中 输入 欲 查询 的 关键 字 ， 在 下 拉 列 
表 框 中 选择 要 搜索 的 信息 类 型 ， 然 后 单 击 “ 开 始 搜索 ”按钮 ， 对 指定 条 件 的 记录 进行 检索 并 输出 结果 
集 到 浏览 器 ， 同 时 ， 为 了 方便 浏览 者 查找 自己 所 关注 的 内 容 信息 ， 本 模块 对 查询 关键 字 进 行 描 红 。 运 
行 结果 如 图 28.8 所 示 。 
(MC 昂 坦 供求 信息 冉 i 
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各 沪 另 查 供求 网 , 生活 更 轻松 
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矶 间作 天 信忠 同 re_ Vel10 cve 版 权 所 有 联系 量 活 : 0431 049TD9e* 


图 28.8 信息 检索 页 面 运 行 结果 
28.3.5 “后台 功能 模块 设计 


程序 开发 人 员 在 设计 网 站 后 台 时 ， 主 要 考虑 功能 的 易 操 作 性 、 实 用 性 和 易 维护 性 。 供 求 信 息 网 后 
台 主 要 包含 以 下 内 容 : 

回 ”发布 付 费 的 供求 信息 (包括 公寓 信息 、 招 聘 信息 、 求 职 信息 、 培 训 信 息 、 家 教 信息 、 房 屋 信 
息 、 车 辆 信息 、 求 购 信息 、 出 售 信息 、 招 商 引 资 、 寻 人 / 物 启示 等 ) ， 以 及 付费 信息 的 浏览 、 
审核 及 删除 功能 。 
免费 信息 的 浏览 、 审 核 及 删除 功能 。 
企业 广告 信息 的 发 布 、 浏 览 、 前 台 推荐 显示 、 删 除 功能 。 

网 站 首页 ， 为 管理 员 进 入 前 台 提供 一 个 入 口 。 
退出 登录 ， 注 销 当前 用 户 。 

其 功能 结构 如 图 28.9 所 示 。 

后 台 管 理 模 块 运行 结果 如 图 28.10 所 示 。 
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图 28.10 后 台 管 理 模块 运行 结果 
28.3.6 ”付费 供求 信息 发 布 模块 设计 


付费 供求 信息 发 布 的 提供 对 象 为 供求 信息 用 户 ， 是 供求 信息 网 站 非常 重要 的 功能 ， 也 是 供求 信息 
网 站 的 鼻 利 点 。 企 业 或 用 户 可 以 根据 自身 需要 对 供求 信息 先进 行 付费 ， 付 费 后 由 管理 员 在 后 台 将 供求 
信息 发 布 到 相应 的 信息 类 别 中 招聘 信息 、 求 职 信息 、 培 训 信息 、 公 寓 信 息 、 家 教 信息 、 车 辆 信息 、 
物品 求购 、 物 品 出 售 、 求 兑 出 竞 、 寻 求 合 作 、 企 业 广告 》。 供 求 信息 成 功 发 布 后 ， 管 理 员 需要 在 后 台 
对 发 布 的 供求 进行 审核 ， 如 果 审 核 通过 ， 则 显示 在 前 台 相应 的 信息 类 别 网 页 中 。 付 费 供求 信息 发 布 的 
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流程 图 如 图 28.11 所 示 。 
用 户 通过 单 击 页 面 导航 区 的 “付费 信息 ” 超 链接 ， 进 入 付费 信息 发 布 页 面 ， 如 图 28.12 所 示 。 填 写 
真实 有 效 的 付费 信息 ， 单 击 “ 发 布 信息 ”按钮 ， 程 序 会 先 来 验证 用 户 是 否 输入 的 信息 ， 若 验证 失败 ， 


则 返回 信息 发 布 页 面 ， 进 行 相应 提示 。 若 验证 成 功 ， 则 向 数据 库 中 插入 记录 ， 完 成 付费 信息 的 发 布 
操作 。 


管理 员 
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本 主 业 厂 六 显示 方式 二 | 
| 
二 CT ED 
在 前 台 展 示 一- 
发 布 的 信息 
28.11 付费 供求 信息 发 布 流程 图 图 28.12 付费 供求 信息 发 布 页 面 运 行 结果 


28.4 本 章 小 结 


本 章 依据 软件 开发 流程 介绍 了 易 查 供求 信息 网 的 开发 过 程 。 在 开发 任何 一 个 项 目前 ， 首 先 要 充分 
做 好 前 期 准备 ， 如 完善 的 需求 分 析 、 清 晰 的 业务 流程 、 合 理 的 程序 结构 等 ， 这 样 ， 在 后 期 的 程序 开发 
中 才 会 得 心 应 手 、 有 备 而 无 患 。 通 过 本 章 的 学 习 ， 读 者 可 以 了 解 供求 信息 网 站 的 开发 流程 ， 熟 悉 框架 
技术 在 Web 应 用 程序 中 的 应 用 。 由 于 篇 幅 所 限 ， 这 里 没有 对 该 网 站 的 开发 进行 详细 讲解 ， 其 具体 的 功 
能 可 参考 本 书 配套 光盘 中 的 源 代 码 。 
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在 图 书馆 中 ， 读 者 可 能 看 到 过 这 样 一 幅 画 面 : 很 多 人 徘徊 于 图 书馆 书架 之 间 ， 
找寻 着 自己 需要 的 图 书 ; 图 书 管理 员 则 翻阅 着 图 书 借 阅 的 记录 ， 坦 看 着 哪些 图 书 被 
借 出 ， 哪 些 需要 昌 还 ， 进 行 着 繁 殉 的 统计 工作 。 而 当 计算 机 进入 到 我 们 的 生活 以 后 ， 
可 以 通过 它 来 管理 图 书馆 中 的 图 书 ， 对 图 书 进行 登记 、 编 号 、 分 类 ; 记录 图 书 的 借 
阅 信息 ; 查询 图 书馆 中 的 图 书 ， 一 切 工 作 都 变 得 那么 简单 、 流 畅 。 不 但 提高 了 工作 
的 效率 , 而 且 使 图 书 的 查询 变 得 方便 、 快 捷 ， 这 就 是 图 书 借阅 管理 系统 的 魅力 所 在 。 
本 章 将 应 用 Apache+PHP+MySQL 开发 一 个 图 书 借阅 管理 系统 , 其 中 应 用 到 的 关键 
技术 和 方法 如 下 : 

Mm 通过 MySQL 国 数 连接 数据 库 的 方法 

Mm” 通过 PHP 国 数 操作 数据 库 的 方法 

MW 面向 对 象 的 编程 方法 

让 自动 计算 图 书 娄 还 日 期 

m 管理 员 权 限 的 设置 方法 

MW” MySQL 中 添加 、 修 改 、 删 除 和 更 新 语句 的 应 用 

H MySQL 中 多 表 查 询 方法 

# MySQL 中 内 联接 和 外 联接 语句 的 应 用 
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29.1 项 目 描述 


知 源 图 书馆 是 吉林 XX 师范 学 校 的 大 型 图 书馆 ， 随 着 学 校 图 书馆 规模 的 不 断 壮大 ， 经 营 图 书 品种 、 
数量 也 逐渐 增多 。 同 时 ， 此 图 书馆 常年 采用 的 传统 的 人 工 方式 管理 暴露 了 一 些 问题 。 例 如 ， 查 找 读者 
借阅 的 某 一 本 图 书 的 具体 摆 放 位 置 ， 需 要 靠 人 工 记忆 在 书 海 中 苦 苦 查 找 ， 由 于 图 书 储存 量 大 ， 很 难 准 
确定 位 图 书 的 具体 位 置 ， 因 此 每 天 都 要 浪费 大 量 的 人 力 资 源 。 

学 校 图 书馆 为 提高 工作 效率 ， 同 时 摆脱 图 书 管理 人 员 在 工作 中 出 现 的 种 种 弊端 ， 现 决定 开发 一 个 
学 校 图 书馆 管理 系统 ， 通 过 计算 机 对 图 书 进行 管理 。 

图 书馆 管理 系统 为 图 书馆 注入 了 新 的 生机 ， 不 但 在 运营 过 程 中 节省 了 大 量 的 人 力 、 物 力 、 财 力 和 
时 间 ， 提 高 了 图 书馆 的 效率 ， 而 且 还 为 图 书馆 在 读者 群 中 树立 了 一 个 全 新 的 形象 ， 为 图 书馆 日 后 的 发 
展 黄 定 了 一 个 良好 的 基础 。 

通过 对 一 些 大 型 图 书馆 的 实际 考察 、 分 析 ， 并 结合 图 书馆 的 要 求 以 及 实际 的 市 场 调查 ， 要 求 本 系 
统 具 有 以 下 功能 : 
系统 页 面 设计 美观 大 方 、 个 性 化 ， 功 能 全 面 ， 操 作 简单 。 
实现 基础 信息 的 管理 平台 。 

回 统计、 管理 读者 信息 。 

回 ”统计 图 书 借 阅 排行 ， 了 解 当前 的 畅销 书 。 

回 ”商品 分 类 详尽 ， 可 按 不 同类 别 查 看 图 书信 息 。 

回 ”提供 快速 的 图 书信 息 、 图 书 借阅 检索 功能 ， 保 证 数据 查询 的 灵活 性 。 

回 ”实现 图 书 借阅 、 图 书 续 借 、 图 书 归 还 的 功能 。 

回 ”实现 综合 条 件 查询 ， 如 按 用 户 指定 条 件 查询 、 按 日 期 时 间 段 查询 、 综 合 条 件 查 询 等 。 

回 ”实现 对 图 书 借阅 、 续 借 和 归还 过 程 的 全 程 数 据 信息 跟踪 。 
名 
回 
回 
回 
图 


加 回 


提供 借阅 到 期 提醒 功能 ， 使 管理 者 可 以 及 时 了 解 到 已 经 到 达 归 还 日 期 的 图 书 借阅 信息 。 
提供 灵活 、 方 便 的 权限 设置 功能 ， 使 整个 系统 的 管理 分 工 明确 。 

具备 稳定 的 数据 库 系统 。 

安全 性 高 ， 易 于 维护 。 

书 借阅 管理 系统 主页 的 运行 效果 如 图 29.1 所 示 。 


图 29.1 图 书 借阅 管理 系统 的 主页 
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图 书 档案 管理 页 面 如 图 29.2 所 示 。 
图 书 借阅 操作 页 面 如 图 29.3 所 示 。 


全 图书 这 外 理 系统 


(TT 


图 29.2 图 书 档案 管理 页 面 图 29.3 图 书 借阅 操作 页 面 
29.2 技术 准备 


在 开发 图 书 借阅 管理 系统 时 ， 该 项 目 所 使 用 的 软件 及 开发 环境 如 下 。 
回 “服务 器 端 

> 操作 系统 ，Windows 2003 ServerLinux (推荐 ) 。 
服务 器 : Apache 2.2。 
PHP 软件 : PHP 5.1.6。 
数据 库 : MySQL 5.0.24。 
MySQL 图 形 化 管理 软件 : phpMyAdmin-2.9.0.2。 
开发 工具 : Dreamweaver 8。 
浏览 器 : IE 6.0 及 以 上 版 本 。 

> “分 辩 率 : 最 佳 效 果 1024X768 像素 。 
客户 端 

> 浏览 器 : IE 6.0 及 以 上 版 本 。 

> 分辩 率 : 最 佳 效果 1024X768 像素 。 


VvvyvyvyY 


29.3 开发 过 程 


29.3.1 数据库 设计 


图 书 借阅 管理 系统 的 开发 ， 数 据 库 是 必 不 可 少 的 内 容 ， 需 要 通过 数据 库 来 存储 图 书 档案 数据 、 读 
者 档案 数据 、 图 书 借阅 记录 数据 、 图 书 归 还 记录 数据 和 管理 员 数 据 。 从 开发 的 成 本 和 用 户 需求 考虑 ， 


中 
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使 用 MySQL 数据 库 是 最 为 合适 的 选择 。 
结合 实际 情况 及 对 用 户 需 求 的 分 析 ， 图 书 借阅 管理 系统 db_database29 数据 库 主要 包含 10 个 数据 
表 ， 如 图 29.4 所 示 。 


回 服务 器 : localhost ， 昌 数据 库 : db_database29 
表 类 型 整理 


也 _hookcase 。 MySAM 。 gb2312_chinese_ci 。 图 节 书 架 信息 表 
也 _hookinfo 。 WiSAM 。 gb2312_chinese_cl 。 图 书信 息 表 

也 _horrow MYSAM 。 gb2312_chinese_ci 。 图 书 借阅 信息 表 
节 mbray MWSAM gb2312_chinese_ci 。 图 书信 信息 表 
也 _manager 。 MYISAM 。 gb2312_chinese_ci 。 管理 员 信息 表 
也 _parameter ”MYISAM 。 gb2312_chinese_cl 。 参数 设置 信息 表 
也 _publishing 。 MYSAM 。 gb2312_chinese_cl 。 出 版 社 信息 表 
也 _purWew MYSAM 。 gb2312_chinese_cl 。 权限 信息 表 

tb reader 。。 MYISAM gb2312_chinese_ci 。 读者 信息 表 
tb _readertype MYSAM 。 gb2312_chinese_cl 。 读者 尖 型 信息 表 


29.4 图 书 借阅 管理 系统 数据 表 


29.3.2 ”功能 模块 概述 


图 书 借阅 管理 系统 主要 分 为 6 个 部 分 ， 每 个 部 分 中 包括 多 个 具体 的 功能 模块 。 图 书 借阅 管理 系统 
的 整体 功能 结构 如 图 29.5 所 示 。 


图 读 
书 者 书 | | 书 
入 类 档 | | 借 
型 案 || 阅 
| 管 查 || 查 
理 询 | | 询 


图 29.5 图 书 借阅 管理 系统 整体 功能 结构 图 
29.3.3 ”管理 员 模块 


管理 员 模块 的 功能 包括 管理 员 登 录 、 查 看 管理 员 列 表 、 添 加 管理 员 信息 、 管 理 员 权限 设置 、 管 理 
员 删 除 和 更 改口 令 等 。 管 理 员 模块 的 框架 图 如 图 29.6 所 示 。 
首先 是 管理 员 登 录 ， 用 于 验证 管理 员 的 身份 。 运 行 本 系统 ， 首 先进 入 的 是 管理 员 登 录 页 面 ， 在 该 
页 面 中 ， 系 统管 理 员 可 以 通过 输入 正确 的 管理 员 名 称 和 密码 登录 到 系统 首页 ， 当 用 户 没 有 输入 管理 员 名 
称 或 密码 时 ， 系 统 会 通过 JavaScript 进行 判断 ， 并 给 予 提示 信息 。 管 理 员 登录 页 面 的 运行 结果 如 图 29.7 
所 示 。 


636 
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管理 员 登 录 后 ， 选 择 “ 系 统 设置 ”/“ 管 理 员 设置 ”命令 ， 进 入 到 查看 管理 员 列 表 页 面 ， 页 面 中 将 
以 表格 的 形式 显示 全 部 管理 员 及 其 权限 信息 ， 并 提供 添加 管理 员 信息 、 删 除 管 理 员 信息 和 设置 管理 员 
权限 的 超 链接 。 管 理 员 列表 页 面 的 运行 结果 如 图 29.8 所 示 。 


否 
拔 生 通过 验 
是 
管理 员 列表 
4 了 了 y 
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图 29.6 管理 员 模 块 的 框架 图 
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图 29.8 管理 员 列 表 页 面 的 运行 结果 
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29.3.4 图 书 档案 管理 模块 


图 书 档案 管理 模块 的 功能 包括 查看 图 书 列表 、 添 加 图 书信 息 、 修 改 图 书信 息 、 删 除 图 书信 息 和 查 
看 图 书 详细 信息 等 。 图 书 档案 模块 的 框架 图 如 图 29.9 所 示 。 


开始 


图 书信 息 列表 


| 到 所 图 书 列表 | | 加 书信 | | 站 全 | 开除 田 书信 息 | | 查看 图 书 详细 信息 | 


图 29.9 图 书 档案 模块 的 框架 图 
管理 员 登 录 后 ， 选 择 “ 图 书 管理 ”/“ 图 书 档案 管理 ”命令 ， 进 入 到 查看 图 书 列 表 页 面 ， 在 该 页 面 
中 将 显示 全 部 图 书信 息 列表 ， 同 时 提供 添加 图 书信 息 、 删 除 图 书信 息 、 修 改 图 书信 息 的 超 链接 。 图 书 
信息 列表 页 面 的 运行 结果 如 图 29.10 所 示 。 


当前 详 置 ; 图 书 芝 理 医术 案 和 理 


争 开 三 图 书 各 称 四 出 版 村 be 人 出 除 
二 456T99 。。 Pir 妆 所 康 系 统 开发 全 手 用 数 权 库 技 本 人 民 邮 电 出 版 村 。 ir 书架 [ 
123454321 二 奥 基 人 民 各 电 出 找 社 PE 加 [SL 
07354321 利息 科学 技术 人 民 闻 电 出 版 村 。 FIP 书架 [SL 
pay115t5t101 Ves 近 件 光大 计算 也 温 序 设计 。。 人 民 出 电 出 疡 社 。 和 加 [a 


Copy eht 日 2007 mv nryced com 吉林 to 了 范 大 学 辐 必 从 
本 直 清 二 用 IE 6.0 或 以 上 版 地 1024rT66 为 最 秆 显示 获 果 


图 29.10 ”图书 信息 列表 的 运行 结果 


29.3.5 ”图 书 借 还 模块 


图 书 借 还 模块 主要 包括 图 书 借阅 、 图 书 续 借 、 图 书 归 还 、 图 书 档案 查询 、 图 书 借阅 查询 、 借 阅 到 
期 提醒 等 功能 。 在 图 书 借阅 模块 中 的 用 户 只 有 一 种 身份 ， 即 操作 员 ， 通 过 该 身份 可 以 进行 图 书 借 还 等 
相关 操作 。 图 书 借 还 模块 的 用 例 图 如 图 29.11 所 示 。 

管理 员 登 录 后 ， 选 择 “ 图 书 借 还 ”/“ 图 书 借阅 ”命令 ， 进 入 到 图 书 借阅 页 面 ， 在 该 页 面 中 的 “ 读 
者 条 形 码 ”文本 框 中 输入 读者 的 条 形 码 ( 如 123456789) 后 ， 单 击 “ 确 定 ” 按 钮 ， 系 统 会 自动 检索 出 该 
读者 的 基本 信息 和 未 归还 的 图 书 借阅 信息 。 如 果 检 索 到 对 应 的 读者 信息 ， 将 其 显示 在 页 面 中 ， 此 时 输 
入 图 书 的 条 形 码 或 图 书 名 称 后 ， 单 击 “确定 ”按钮 ， 即 可 借阅 指定 的 图 书 。 图 书 借阅 页 面 的 运行 结果 
如 图 29.12 所 示 。 
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图 29.11 图 书 借 还 模块 的 用 例 图 
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图 29.12 图 书 借阅 页 面 的 运行 结果 


管理 员 登 录 后 ， 选 择 “ 图 书 借 还 ”/“ 图 书 续 借 ”命令 ， 进 入 到 图 书 续 借 页 面 ， 在 该 页 面 中 的 “ 读 
者 条 形 码 ” 文 本 框 中 输入 读者 的 条 形 码 ( 如 123456789) 后 ， 单 击 “ 确 定 ”按钮 ， 系 统 会 自动 检索 出 该 
读者 的 基本 信息 和 未 归还 的 图 书 借阅 信息 。 如 果 检 索 到 对 应 的 读者 信息 ， 则 将 其 显示 在 页 面 中 ， 此 时 


单 击 “ 续 借 ” 超 链接 ， 即 可 续 借 指定 图 书 (将 该 图 书 的 归还 时 间 加 上 该 书 的 可 借 天 数 得 出 )。 图 书 续 
借 页 面 的 运行 结果 如 图 29.13 所 示 。 
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图 29.13 ”图书 续 借 页 面 的 运行 结果 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


附录 A PHP 编码 规则 


PHP 编码 规则 不 是 一 个 定理 、 一 个 公式 , 不 需要 PHP 程序 员 去 刻意 遵循 , 但 是 如 果 PHP 程序 员 遵 
循 PHP 编码 规则 ， 就 可 以 提高 代码 的 质量 、 程 序 的 可 维护 性 ， 及 开发 速度 和 效率 。 如 果 是 团队 开发 项 
目 ， 还 可 以 让 参与 项 目的 其 他 开发 人 员 更 容易 了 解 项 目 中 的 代码 ， 和 弄 清 程序 的 状况 ， 更 快 地 投入 到 项 
目 开发 的 工作 中 来 。 

如 果 是 闭门造车 ， 形 成 一 套 自 己 的 编码 风格 ， 就 会 导致 编写 的 东西 只 有 自己 才能 看 懂 ， 其 他 人 在 
阅读 时 会 浪费 过 多 的 时 间 和 精力 ， 不 易于 对 程序 的 维护 、 更 新 。 如 果 是 团队 开发 项 目 ， 就 很 难 投入 到 
项 目的 开发 工作 中 ， 因 为 其 他 人 不 了 解 这 个 编码 规则 ， 也 就 不 能 快速 地 阅读 相应 的 程序 代码 。 


A.1 PHP File 文件 格式 


A.1.1 常规 


对 于 只 包含 PHP 代码 的 文件 ， 结 束 标志 〈"?>") 是 不 允许 存在 的 ， 否 则 会 导致 文件 末尾 被 意外 地 
注入 空白 并 显示 输出 。 
由 _HALT_COMPILERO 人 允许 的 任意 的 二 进 制 代码 的 内 容 被 Zend Framework PHP 文件 或 由 它们 产 
生 的 文件 禁止 。 这 个 功能 只 对 特殊 的 安装 脚本 开放 。 


A.1.2 缩 进 


使 用 4 个 空格 的 缩 进 ， 而 不 使 用 制 表 符 TAB。 


A.1.3 行 的 最 大 长 度 


一 行 在 80 个 字符 以 内 比较 合适 ， 长 些 也 可 以 ， 但 最 多 为 120 个 字符 。 
A.1.4 行 结束 标志 
行 结束 标志 只 能 是 标准 的 UNIX 文本 文件 的 换行 ,换行 符 在 文件 中 表示 为 10, 或 十 六 进 制 的 0x0A。 


不 要 使 用 Macintosh 的 回 车 ， 如 (COx0OD) 。 
不 要 使 用 Windows 的 回 车 换行 组 合 ， 如 (0x0D,0x0A) 。 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 
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程序 块 划分 尽量 合理 ， 过 大 或 者 过 小 的 分 割 都 会 影响 他 人 对 代码 的 阅读 和 理解 ， 一 般 以 较 大 函数 
定义 、 罗 辑 结 构 、 功 能 结构 来 进行 划分 。 少 于 15 行 的 程序 块 ， 可 不 加 上 下 空白 行 。 

说 明 或 显示 部 分 中 ， 内 容 如 中 文 、 数 字 、 英 文 单词 混杂 ， 应 当 在 数字 或 者 英文 单词 的 前 后 加 入 空格 。 

符合 上 述 编码 规范 的 示例 代码 如 下 : 

Sresult= (($Sa+ 1)* 3/2+ $num)).Test: 

S$condition ? func1($var) : func2($var): 

Scondition ? Slong_statement 


: $another long statement; 
if (Sflag) 


//Statements 
//More than 15 lines 


} 
Showmessage( “请 使 用 restore php 工具 恢复 数据 。”): 


A2 命名 约定 
A.2.1 类 


类 名 只 允许 有 字母 和 数字 字符 ， 但 不 鼓励 使 用 数字 。 下 划 线 只 允许 作为 路 径 分 隔 符 ， 如 Zend/ 
Db/Table.php 文件 中 对 应 的 类 名 称 是 Zend_Db_Table。 

如 果 类 名 包含 多 个 单词 ， 每 个 单词 的 第 一 个 字母 必须 大 写 ， 连 续 的 大 写 是 不 允许 的 ， 例 如 ， 
Zend_ PDF 是 不 允许 的 ， 而 Zend_Pdf 是 可 接受 的 。 

由 Zend 或 其 参与 Zend Framework 项 目的 伙伴 公司 发 行 的 类 必须 以 Zend_ 开头 并 且 必 须 按 等 级 顺 
序 放 在 Zend/ 目 录 下 。 


A.2.2 接口 
接口 类 也 必须 遵循 同样 的 约定 〈 如 上 所 述 ) ， 但 必须 以 Interface 结尾 ， 例 如 : 


Zend Log Adapter Interface 
Zend_ Controller Dispatcher Interface 


A.2.3 文件 名 
对 于 其 他 文件 ， 只 有 字母 和 数字 字符 、 下 划 线 和 短 横 线 “-” 可 用 ， 空 格 是 不 允许 的 。 


包含 任何 PHP 代码 的 任何 文件 必须 以 .php 扩展 名 结尾 。 
普通 程序 和 能 够 被 URL 直接 调用 的 程序 ， 如 list.php、index.php， 可 以 直接 使 用 “程序 名 +.php” 
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的 方式 命名 。 

函数 库 和 类 库 程序 ， 应 以 小 写 .func.php 和 .class.php 作为 扩展 名 。 函 数 库 和 类 库 程 序 只 能 被 其 他 程 
序 引 用 ， 而 不 能 独立 运行 。 其 中 ， 不 能 包含 任何 流程 性 的 、 不 属于 任何 函数 或 类 的 程序 代码 。 

流程 性 程序 ， 以 小 写 .inc.php 作为 扩展 名 。 只 能 被 其 他 程序 引用 ， 而 不 能 独立 运行 。 其 中 ， 不 能 包 
含 任何 函数 或 类 代码 的 程序 代码 。 

模板 源 文件 ， 以 小 写 .html 作为 扩展 名 。 模板 源 文件 按照 PHP 模板 编码 规则 进行 编写 ,不 是 可 执行 
的 程序 ， 而 只 能 被 PHP 模板 编译 器 所 解析 ， 放 置 于 ./templates/default 或 ./templates 目录 下 。 

模板 目标 文件 ， 模 板 文件 被 编译 后 自动 生成 的 目标 程序 ， 以 小 写 .php 作为 扩展 名 ， 存 放 
于 ./data/templates 目录 下 。 

语言 包 文件 ， 以 小 写 .lang.php 作为 扩展 名 ， 只 能 存放 模板 或 程序 使 用 的 语言 包 信息 。 

缓存 文件 ， 此 类 文件 为 系统 自动 生成 ， 以 cache xxx.php、usergroup_xxx.php、style_xxx.php 等 类 
似 形式 命名 ， 存 放 于 ./data/cache 目录 下 。 

文件 名 必须 遵循 上 述 的 对 应 类 名 的 规则 。 


A.2.4 函数 和 方法 


函数 名 只 能 包含 字母 和 数字 字符 ， 但 不 鼓励 使 用 数字 ， 不 允许 使 用 下 划 线 。 

函数 名 总 是 以 小 写字 母 开 头 ， 当 函数 名 包含 多 个 单词 时 ， 每 个 单词 的 首 字母 必须 大 写 ， 这 就 是 所 
谓 的 “驼峰 ”格式 。 

鼓励 使 用 宛 长 的 名 字 ， 这 样 容 易 理解 代码 。 下 面 是 符合 约定 的 命名 : 

filterInputO 

getElementById0 

widgetFactoryO 

对 于 面向 对 象 编程 , 对 象 的 访问 器 总 是 以 get 或 set 为 前 级 。 当 使 用 设计 模式 如 单 态 模式 (singleton) 
或 工厂 模式 〈factory) 时， 方法 的 名 字 应 当 包 含 模式 的 名 字 ， 这 样 容易 从 名 字 识 别 设计 模式 。 

在 对 象 中 的 方法 ， 声 明 为 private 或 protected 的 ， 名 称 的 首 字符 必须 是 一 个 单独 的 下 划 线 ， 这 是 唯 
一 的 下 划 线 在 方法 名 字 中 的 用 法 。 声 明 为 public 的 方法 不 以 下 划 线 开头 。 

允许 但 不 鼓励 全 局 函数 floating functions)， 建 议 把 这 类 函数 封装 到 静态 类 中 。 

以 标准 计算 机 英文 为 蓝本 ， 尽 量 避 免 使 用 拼音 或 拼音 英文 混合 的 命名 方式 。 

函数 的 名 字 和 变量 的 命名 规范 一 致 。 

函数 定义 中 的 左 小 括号 与 函数 名 之 间 无 空格 。 

开始 的 左 大 括号 另 起 一 行 。 

具有 默认 值 的 参数 应 该 位 于 参数 列表 的 后 面 。 

函数 定义 与 调用 的 参数 之 间 加 入 一 个 空格 。 

尽量 避免 函数 起 始 缩 进 位 置 与 结束 缩 进 位 置 不 同 。 

符合 上 述 书写 规则 的 函数 定义 方法 如 下 : 

function authcode($string. $operation, $key = ") 

{ 
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if(sflag) 
{ 


//Statement 


by 
/函数 体 
| 


A.2.5 变量 


变量 只 包含 数字 和 字母 字符 ， 不 鼓励 使 用 数字 ， 不 允许 为 下 划 线 。 

声明 为 private 或 protected 的 类 成 员 变 量 名 必须 以 一 个 单独 的 下 划 线 开头 , 这 是 唯一 的 下 划 线 在 变 
量 名 中 的 用 法 。 声 明 为 public 的 变量 从 不 以 下 划 线 开头 。 

与 函数 名 一 样 ， 变 量 名 总 以 小 写字 母 开 头 并 遵循 “驼峰 式 ” 命 名 约定 。 

鼓励 使 用 宛 长 的 名 字 ， 这 样 容 易 理解 代码 。 除 在 小 循环 中 以 外 ， 不 鼓励 使 用 简洁 的 名 字 〈 如 $i 和 
$n) 。 如 果 一 个 循环 超过 20 行 代码 ， 索 引 的 变量 名 必须 是 具有 描述 意义 的 名 字 。 

变量 命名 只 能 使 用 项 目 中 有 据 可 查 的 英文 缩写 方式 , 例如 , 可 以 使 用 $data 而 不 可 使 用 $datal 、$data2 
这 样 容易 产生 混淆 的 形式 ， 应 当 使 用 $username、$password 这 样 能 使 人 一 目 了 然 容易 理解 的 形式 。 

可 以 合理 地 对 过 长 的 命名 进行 缩写 ， 如 $bio($biography)、$tpp($threadsPerPage)， 前 提 是 英文 中 存 
在 这 样 既 有 的 缩写 形式 ， 或 字母 符合 英文 缩写 规范 。 

必须 清楚 所 使 用 英文 单词 的 词性 ， 在 权限 相关 的 范围 内 ， 大 多 使 用 $enable***、S$is*** 的 形式 ， 前 
者 后 面 接 动词 ， 后 者 后 面 接 形容 词 。 

下 面 是 一 些 基 本 的 命名 规则 : 
名 称 的 开头 不 能 使 用 数字 及 特殊 符号 。 
“。” 及 类 型 声明 等 专用 语 不 能 作为 名 称 。 
变量 或 程序 名 的 长 度 必须 在 255 个 字符 以 内 。 
和 保留 字 相同 的 名 称 不 能 使 用 。 


加 加 图 回 


A.2.6 常量 


常量 包含 数字 、 字 母 和 下 划 线 ， 数 字 允 许 作为 常量 名 。 

常量 名 的 所 有 字母 必须 大 写 。 

为 加 强 可 读 性 ， 常 量 中 的 单词 必须 以 下 划 线 分 隔 ， 例 如 ， 可 以 使 用 EMBED_SUPPRESS_EMBED_ 
EXCEPTION， 但 是 不 允许 使 用 EMBED_SUPPRESSEMBEDEXCEPTION。 

常量 必须 通过 const 定义 为 类 的 成 员 ， 不 鼓励 使 用 define 定义 的 全 局 常量 。 


A.2.7 ”数据 库 表 和 字段 


表 和 字段 的 命名 以 命名 原则 中 定义 的 规范 为 依据 。 
所 有 数据 表 名 称 ， 只 要 其 名 称 是 可 数 名 词 ， 应 尽量 以 复数 方式 命名 ;存储 多 项 内 容 的 字段 ， 或 代 
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表 数量 的 字段 ， 也 应 当 以 复数 方式 命名 ， 如 hits (查看 次 数 ) 、items (内 容 数量 ) 。 
当 几 个 表 间 的 字段 有 关联 时 ， 要 注意 表 与 表 之 间 关 联 字段 命名 的 统一 ， 如 forum_articles 表 中 的 
articleid 与 forum restores 表 中 的 articleid 。 
代表 ID 自 增 量 的 字段 ， 通 常用 以 下 几 种 形式 : 
加 ”一般 情况 下 ， 使 用 全 称 的 形式 ， 如 userid、articleid。 
回 没有 功能 性 作用 ， 只 为 管理 和 维护 方便 而 设 的 ID， 可 以 使 用 全 称 的 形式 ， 也 可 只 将 其 命名 
为 ID。 


A3 编码 风格 


A.3.1 PHP 代码 划分 (Demarcation) 


PHP 代码 总 是 用 完整 的 标准 的 PHP 标签 定 界 : 
<?php 
x 


短 标签 (<? ?>) 是 不 允许 的 ， 只 包含 PHP 代码 的 文件 不 要 结束 标签 。 
A.3.2 ”字符 串 


1. 字符 串 文字 

如 果 字 符 串 是 文字 (不 包含 变量 ) ， 则 用 单 引 号 (apostrophe) 引起 来 : 

$a = 'Example String': 

2. 包含 单 引号 〈') 的 字符 串 文字 

如 果 文字 字符 串 包 含 单 引号 (apostrophe) ， 就 用 双 引号 引起 来 ， 特 别 是 在 SQL 语句 中 : 
$sql = "SELECT 'id', ‘name' from 'people' WHERE 'name 一 Fred' OR ‘name'='Susan": 

在 转 义 单 引 号 时 ， 上 述 语法 是 首选 。 

3. 变量 替换 

变量 替换 有 下 面 两 种 形式 : 


Sgreeting = "Hello $name, welcome back!": 
Sereeting = "Hello {$name}, welcome back!": 


为 保持 一 致 ， 下 面 的 形式 是 不 允许 的 : 


Sereeting = "Hello $ {name}. welcome back!": 
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码 。 示 例如 下 : 


/中 
* Documentation Block Here 
class ExampleClass 


// entire content of class 
// must be indented four spaces 
} 


2. 类 成 员 变 量 

必须 用 下 面 的 变量 名 约定 来 命名 类 成 员 变量 : 

回 ”变量 的 声明 必须 在 类 的 项 部， 要 先 于 方法 的 声明 。 
回 ”不 允许 使 用 var， 应 使 用 private、protected 或 public。 


A.3.5 ”函数 和 方法 


1 函数 和 方法 声明 

必须 用 下 面 的 变量 名 约定 来 命名 函数 : 

回 ”在 类 中 的 函数 必须 用 private、protected 或 public 声明 其 可 见 性 。 

加 ”和 类 一 样 ， 花 括号 从 函数 名 的 下 一 行 开始 ， 函 数 名 与 包括 参数 的 圆 括号 中 间 没 有 空格 。 
回 ”不 能 使 用 全 局 函数 。 

id 

* Documentation Block Here 

ih 

class Euspice 


{ 


/中 让 
* Documentation Block Here 
public function cattle0 
{ 
// entire content of function 
// must be indented four spaces 
b 
} 
2. 函数 和 方法 的 用 法 
函数 的 参数 用 逗号 和 空格 将 紧 接 着 的 参数 分 隔 。 下 面 例子 中 的 函数 带 有 3 个 参数 : 


threeAreuments(1, 2, 3): 
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传 值 方式 在 调用 时 是 禁止 的 。 
带 有 数组 参数 的 函数 ， 函 数 的 调用 可 包括 array 并 分 成 多 行 来 提高 可 读 性 ， 同 时 ， 书 写 数组 的 标准 
仍然 适用 : 


threeArguments(array(1, 2. 3), 2. 3); 
threeArguments(array(1. 2, 3, 'Zend', 'Studio', 
S$a, $b, $c, 
56.44. $d, 500). 2. 3): 


A.3.6 ”控制 语句 


1. if/else/elseif 
使 用 ipelse/elseif 的 控制 语句 时 ， 在 条 件 语句 的 圆 括 号 前 后 都 必须 有 一 个 空格 。 
在 圆 括号 中 的 条 件 语句 ， 操 作 符 必须 用 空格 分 开 ， 鼓 励 使 用 多 重 圆 括号 以 便 在 复杂 的 条 件 中 划分 
逻辑 组 合 。 
前 花 括号 必须 和 条 件 语句 在 同一 行 ， 后 花 括 号 单独 在 最 后 一 行 ， 其 中 的 内 容 用 4 个 空格 缩 进 。 
让 (Sal=2){ 
$a=2; 


} 
下 面 的 例子 应 用 过 、else 和 elseif， 符 合 上 述 格式 约定 : 
if($a (=2) { 

$a=2; 


} else{ 
$a=7; 


} 
if($a!=2){ 
$a=2; 

} elseif ($a == 3) { 
$a=4; 

}else { 
$a=7; 

} 


在 有 些 情况 下 ，PHP 允许 这 些 语句 不 用 花 括号 ， 但 在 ZF 代码 标准 里 ， 让 、elseif 或 else 语句 必须 
使 用 花 括 号 。 

elseif 是 允许 的 但 强烈 不 鼓励 使 用 ， 最 好 使 用 else 让 组 合 。 

2. switch 

在 switch 结构 的 控制 语句 中 ， 条 件 语句 的 圆 括号 前 后 都 必须 有 一 个 单独 的 空格 。 

switch 中 的 代码 必须 有 4 个 空格 缩 进 ， 在 case 中 的 代码 再 缩 进 4 个 空格 。 


switch ($numPeople) { 
case 1: 
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switch 语句 中 必须 有 default。 


A.3.7 数据库 


1. 字段 结构 

允许 NULL 值 的 字段 ， 数 据 库 在 进行 比较 操作 时 ， 会 先 判断 其 是 否 为 NULL， 非 NULL 时 才 进行 
值 的 比较 。 因 此 基于 效率 的 考虑 ， 所 有 字段 均 不 能 为 空 。 

2. SQL 语句 

所 有 SQL 语句 中 ， 除 了 表 名 、 字 段 名 称 以 外 ， 全 部 语句 和 函数 均 需 大 写 ， 应 当 杜绝 小 写 形式 或 大 
小 写 混杂 的 写法 ， 如 “select * from tb_user; ”是 不 符合 规范 的 写法 。 

长 SQL 语句 应 当 有 适当 的 断 行 ， 依 据 JOIN、FROM、ORDER BY 等 关键 字 进 行 界定 。 

通常 情况 下 , 在 对 多 表 进 行 操作 时 , 要 根据 不 同 表 的 名 称 , 对 每 个 表 指 定 一 个 1 一 2 个 字母 的 缩写 ， 
以 使 语句 简洁 并 提高 可 读 性 。 下 面 的 SQL 语句 是 符合 编码 规范 的 : 

Sresult = $db->query("Select m.*, i.* 


FROM ".TABLE MEMBER." m, ".TABLE MEMBERINFO."i 
Where m.userid=i.userid AND m.userid='$_userid"): 


3. 定 长 表 与 变 长 表 
包含 任何 varchar、text 等 变 长 字段 的 数据 表 ， 即 为 变 长 表 ， 反 之 则 为 定 长 表 。 
对 于 变 长 表 ， 由 于 记录 大 小 不 同 ， 在 其 上 进行 许多 删除 和 更 改 将 会 使 表 中 的 碎片 更 多 ， 需 要 定期 
运行 OPTIMIZE TABLE 以 保持 性 能 ， 而 定 长 表 就 没有 这 个 问题 。 
如 果 表 中 有 可 变 长 的 字段 ， 将 它们 转换 为 定 长 字段 能 够 改进 性 能 ， 因 为 定 长 记录 易于 处 理 。 但 在 
这 样 做 之 前 ， 应 该 考虑 下 列 问题 : 
回 ”使 用 定 长 列 速度 更 快 ， 但 占用 的 空间 更 多 。char(mD) 类 型 列 的 每 个 值 总 要 占用 n 个 字 节 (即使 
空 串 也 是 如 此 ) ， 因 为 在 表 中 存储 时 ， 值 的 长 度 不 够 将 在 右边 补 空格 。 
回 “varchar(nD) 类 型 的 列 所 占 空间 较 少 ， 因 为 只 给 它们 分 配 存储 每 个 值 所 需要 的 空间 ， 每 个 值 再 加 
一 个 字 节 用 于 记录 其 长 度 。 因 此 ， 如 果 在 char 和 varchar 类 型 之 间 进 行 选择 ， 需 要 对 时 间 与 空 
间作 出 折衷。 
变 长 表 到 定 长 表 的 转换 ， 不 能 只 转换 一 个 可 变 长 字段 ， 必 须 对 它们 全 部 进行 转换 ， 而 且 必须 使 用 
一 个 Alter TABLE 语句 同时 全 部 转换 ， 否 则 转换 将 不 起 作用 。 
有 时 不 能 使 用 定 长 类 型 ， 如 对 于 比 255 字符 更 长 的 字 串 就 没有 定 长 类 型 。 
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在 设计 表 结 构 时 如 果 能 够 使 用 定 长 数据 类 型 尽量 用 定 长 的 ， 因 为 定 长 表 的 查询 、 检 索 、 更 新 速度 
都 很 快 。 必 要 时 可 以 把 部 分 关键 的 、 承 担 频繁 访问 的 表 进 行 拆 分 。 
进行 表 结构 设计 时 ， 应 当做 到 恰到好处 、 反 复 推 项 ， 从 而 实现 最 优 的 数据 存储 体系 。 
4. 结构 优化 与 索引 优化 
索引 能 加 快 查询 速度 ， 而 索引 优化 和 查询 优化 是 相辅相成 的 ， 既 可 以 依据 查询 对 索引 进行 优化 ， 
也 可 以 依据 现 有 索引 对 查询 进行 优化 ， 这 取决 于 修改 查询 或 索引 哪个 对 现 有 架构 和 效率 的 影响 最 小 。 
索引 优化 与 查询 优化 的 最 基本 准则 如 下 
回 ”根据 产品 的 实际 运行 和 被 访问 情况 ， 找 出 哪些 SQL 语句 是 最 常 被 执行 的 。 最 常 被 执行 和 最 常 
出 现在 程序 中 是 完全 不 同 的 概念 。 最 常 被 执行 的 SQL 语句 ， 又 可 被 划分 为 对 大 表 (数据 条 目 
多 的 ) 和 对 小 表 〈 数 据 条 目 少 的 ) 的 操作 。 无 论 大 表 或 小 表 ， 又 可 分 为 读 (Select) 多 、 写 
(Update/Insert) 多 或 者 读 写 都 多 的 操作 。 
对 常 被 执行 的 SQL 语句 而 言 ， 对 大 表 操 作 需 要 注意 : 
> 写 操作 多 的 ， 通 常 可 使 用 写 入 缓存 的 方法 ， 先 将 需要 写 或 需要 更 新 的 数据 缓存 至 文件 或 
其 他 表 ， 定 期 对 大 表 进 行 批量 写 操作 。 同 时 ， 应 尽量 使 得 常 被 读 写 的 大 表 为 定 长 类 型 ， 
即使 原本 的 结构 中 大 表 并 非 定 长 。 大 表 定 长 化 ， 可 以 通过 改变 数据 存储 结构 和 数据 读 取 
方式 ， 将 一 个 大 表 拆 成 一 个 读 写 多 的 定 长 表 和 一 个 读 多 写 少 的 变 长 表 来 实现 。 
> 读 操作 多 的 ， 需 要 依据 SQL 查询 频率 设置 专门 针对 高 频 SQL 语句 的 索引 和 联合 索引 。 
而 小 表 就 相对 简单 ， 加 入 符合 查询 要 求 的 特定 索引 ， 通 常 效果 比较 明显 。 同 时 ， 定 长 化 小 表 也 有 
益 于 效率 和 负载 能 力 的 提高 。 字 段 比 较 少 的 小 定 长 表 ， 甚 至 可 以 不 需要 索引 。 
回 看 SQL 语句 的 条 件 和 排序 字段 是 否 动态 性 很 高 〈 即 根据 不 同 功 能 开关 或 属性 ，SQL 查询 条 件 
和 排序 字段 的 变化 很 大 的 情况 ) ， 动 态 性 过 高 的 SQL 语句 是 无 法 通过 索引 进行 优化 的 。 唯 一 
的 办 法 只 有 将 数据 缓存 起 来 ， 定 期 更 新 ， 这 适用 于 结果 对 实效 性 要 求 不 高 的 操作 。 
事实 上 ， 索 引 是 将 条 件 查询 、 排 序 的 读 操作 的 资源 消耗 分 布 到 了 写 操作 中 ， 索 引 越 多 ， 耗 费 磁盘 
空间 越 大 ， 写 操作 越 慢 。 因 此 ， 决 不 能 言 目 添加 索引 。 对 字段 索引 与 否 ， 最 根本 的 依据 是 SQL 语句 执 
行 的 概率 、 表 的 大 小 和 写 操作 的 频繁 程度 。 


A.3.8 注释 文档 


程序 注释 中 要 用 简单 、 明 了 、 精 确 的 语言 表达 出 程序 的 处 理 说 明 。 应 避免 每 行程 序 都 使 用 注释 ， 
可 以 在 一 段 程序 的 前 面 加 一 段 注释 ， 要 具有 明确 的 处 理 逻 辑 。 注 释 虽 然 必 不 可 少 ， 但 也 不 应 过 多 ， 不 
要 被 动 地 为 写 注释 而 写 注释 。 

1. 文件 

每 个 包含 PHP 代码 的 文件 必须 至 少 在 文件 顶部 包含 这 些 phpDocumentor 标签 : 

pe 


* 文件 的 简短 描述 
* 文件 的 详细 描述 〈 如 果 有 的 话 ) … … 


加 载 中 


请 耐心 等 待 或 者 刷新 重 试 


本 加 


5. 单行 注释 
短 注释 可 以 显示 在 一 行内 ， 并 与 其 后 的 代码 具有 一 样 的 缩 进 层级 。 如 果 一 个 注释 不 能 在 一 行内 写 
就 应 采用 块 注释 。 单 行 注释 之 前 应 该 有 一 个 空 行 。 以 下 是 一 个 代码 中 单行 注释 的 例子 : 


If (condition) { 
谨 以 下 代码 运行 的 条 件 */ 
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} 


6. 尾 端 注释 
极 短 的 注释 可 以 与 其 所 要 描述 的 代码 位 于 同一 行 ， 但 是 应 该 有 足够 的 空白 来 分 开 代码 和 注释 。 若 
有 多 个 短 注释 出 现 于 大 段 代 码 中 ， 它 们 应 该 具有 相同 的 缩 进 。 
以 下 是 一 个 代码 中 尾 端 注释 的 例子 : 
(sa 一 2{ 
Tetum TRUE: /* 对 单一 条 件 的 说 明 */ 
} Else { 
return isPrime($a); /* 其 余 的 条 件 */ 
} 


7. 行 末 注释 
注释 界定 符 “//”， 可 用 于 注释 整 行 或 者 一 行 中 的 一 部 分 。 


If (SEuspice> 1) { 
// 注 释 用 法 


